@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Philosopher:wght@400;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{overflow-x:hidden;scroll-behavior:smooth}body{background:var(--color-bg-primary);background-attachment:fixed;color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;min-height:100vh;position:relative}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-heading);letter-spacing:var(--letter-spacing-normal)}h1{font-size:var(--font-size-5xl);letter-spacing:var(--letter-spacing-wide)}h2{font-size:var(--font-size-3xl);letter-spacing:var(--letter-spacing-normal)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}a{color:var(--color-link);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-link-hover);text-shadow:var(--glow-primary)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;transition:all var(--transition-base)}input,textarea,select{font-family:inherit;font-size:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);transition:all var(--transition-base)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--glow-focus)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--spacing-md)}@media (max-width: 640px){.container{padding:0 var(--spacing-sm)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.glow-primary{text-shadow:var(--glow-primary)}.glow-secondary{text-shadow:var(--glow-secondary)}.glow-accent{text-shadow:var(--glow-accent)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:var(--radius-md);border:2px solid var(--color-bg-secondary);box-shadow:var(--glow-scrollbar)}::-webkit-scrollbar-thumb:hover{background:var(--color-scrollbar-thumb-hover);box-shadow:var(--glow-scrollbar-hover)}*{scrollbar-width:thin;scrollbar-color:var(--color-scrollbar-thumb) var(--color-bg-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%,to{box-shadow:var(--glow-primary)}50%{box-shadow:var(--glow-primary-strong)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-pulse-glow{animation:pulseGlow 2s ease-in-out infinite}.animate-float{animation:float 3s ease-in-out infinite}:root{--color-primary: #1a2555;--color-primary-light: #2a3565;--color-primary-dark: #0f1538;--color-secondary: #d4af37;--color-secondary-light: #f4e4bc;--color-secondary-dark: #b8941f;--color-accent: #4a9eff;--color-accent-light: #00d4ff;--color-accent-dark: #2a6ec9;--color-bg-primary: linear-gradient(135deg, #0a0e27 0%, #0f1538 50%, #1a2555 100%);--color-bg-secondary: #0f1538;--color-bg-tertiary: #1a2555;--color-bg-card: linear-gradient(135deg, rgba(26, 37, 85, .9) 0%, rgba(15, 21, 56, .95) 100%);--color-text-primary: #e8f4f8;--color-text-secondary: #a8c5d6;--color-text-muted: #7a8fa0;--color-heading: #f4e4bc;--color-link: #d4af37;--color-link-hover: #f4e4bc;--color-success: #00d4ff;--color-warning: #d4af37;--color-error: #ff4a6e;--color-info: #4a9eff;--color-border: #b8941f;--color-border-light: #d4af37;--color-border-hover: #4a9eff;--color-border-focus: #4a9eff;--font-primary: "Philosopher", serif;--font-heading: "Cinzel", serif;--font-code: "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 2.8rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.6;--line-height-relaxed: 1.75;--letter-spacing-tight: 1px;--letter-spacing-normal: 2px;--letter-spacing-wide: 3px;--letter-spacing-wider: 4px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .5rem;--radius-md: .625rem;--radius-lg: .9375rem;--radius-xl: 1.25rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .4);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .6);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .7);--glow-primary: 0 0 20px rgba(212, 175, 55, .5);--glow-primary-strong: 0 0 30px rgba(212, 175, 55, .7);--glow-secondary: 0 0 20px rgba(212, 175, 55, .4);--glow-accent: 0 0 20px rgba(74, 158, 255, .5);--glow-accent-strong: 0 0 30px rgba(74, 158, 255, .7);--glow-focus: 0 0 20px rgba(74, 158, 255, .5);--glow-scrollbar: 0 0 10px rgba(212, 175, 55, .5);--glow-scrollbar-hover: 0 0 15px rgba(212, 175, 55, .7);--shadow-card: 0 10px 40px rgba(74, 158, 255, .3), inset 0 0 30px rgba(74, 158, 255, .1);--shadow-card-hover: 0 10px 40px rgba(74, 158, 255, .5), inset 0 0 30px rgba(74, 158, 255, .2);--color-scrollbar-thumb: #b8941f;--color-scrollbar-thumb-hover: #d4af37;--transition-fast: .15s ease-in-out;--transition-base: .3s ease-in-out;--transition-slow: .5s ease-in-out;--container-max-width: 1280px;--z-background: 1;--z-content: 10;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px}#root{min-height:100vh;position:relative}.icon{user-select:none;-webkit-user-select:none;-moz-user-select:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;transition:all var(--transition-fast);flex-shrink:0}.icon[role=button]{cursor:pointer}.icon[role=button]:hover{transform:scale(1.1);filter:drop-shadow(var(--glow-primary))}.icon[role=button]:active{transform:scale(.95)}.icon[role=button]:focus{outline:2px solid var(--color-border-focus);outline-offset:2px;border-radius:var(--radius-sm)}.icon-text-fallback{background-color:var(--color-bg-secondary);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-weight:var(--font-weight-bold);font-family:var(--font-heading)}.icon-text-fallback[role=button]{cursor:pointer}.icon-text-fallback[role=button]:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-border-light)}.admin-layout{min-height:100vh;display:flex;background:var(--color-bg-primary)}.admin-sidebar{width:280px;min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg-secondary);border-right:2px solid var(--color-border);box-shadow:var(--shadow-lg);position:fixed;top:0;left:0;bottom:0;z-index:var(--z-fixed);transition:transform var(--transition-base)}.sidebar-header{padding:var(--spacing-xl) var(--spacing-lg);text-align:center;border-bottom:2px solid var(--color-border)}.sidebar-title{font-size:var(--font-size-xl);margin-top:var(--spacing-sm);text-shadow:var(--glow-primary);letter-spacing:var(--letter-spacing-normal)}.sidebar-nav{flex:1;padding:var(--spacing-lg) 0;overflow-y:auto}.nav-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.nav-item{padding:0 var(--spacing-md)}.nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-sm);background-color:transparent;transition:all var(--transition-fast);cursor:pointer}.nav-link:hover{background-color:#ffffff0d;color:var(--color-text-primary);box-shadow:var(--glow-primary)}.nav-link.active{background:linear-gradient(135deg,#d4af3733,#b8941f33);color:var(--color-heading);border-left:4px solid var(--color-secondary);padding-left:calc(var(--spacing-lg) - 4px);box-shadow:var(--glow-secondary)}.nav-label{flex:1}.sidebar-footer{padding:var(--spacing-lg) var(--spacing-md);border-top:2px solid var(--color-border)}.logout-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);background-color:#ff4a6e33;border:2px solid var(--color-error);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base)}.logout-button:hover{background-color:#ff4a6e4d;box-shadow:0 0 20px #ff4a6e80;transform:translateY(-2px)}.logout-button:active{transform:translateY(0)}.admin-main{flex:1;margin-left:280px;min-height:100vh;display:flex;flex-direction:column}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-secondary);border-bottom:2px solid var(--color-border);box-shadow:var(--shadow-md);z-index:var(--z-sticky)}.mobile-header-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);font-family:var(--font-heading);color:var(--color-heading)}.mobile-menu-button,.mobile-logout-button{background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.mobile-menu-button:hover,.mobile-logout-button:hover{color:var(--color-secondary);transform:scale(1.1)}.mobile-close-button{display:none;position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:none;border:none;padding:var(--spacing-xs);cursor:pointer;color:var(--color-text-primary);transition:all var(--transition-fast)}.mobile-close-button:hover{color:var(--color-error);transform:rotate(90deg)}.admin-content{flex:1;padding:var(--spacing-2xl) var(--spacing-xl);overflow-y:auto}.mobile-overlay{display:none}@media (max-width: 1024px){.admin-sidebar{transform:translate(-100%)}.admin-sidebar.mobile-open{transform:translate(0)}.mobile-header,.mobile-close-button{display:flex}.admin-main{margin-left:0}.mobile-overlay{display:block;position:fixed;inset:0;background-color:#000000b3;z-index:calc(var(--z-fixed) - 1)}.admin-content{padding:var(--spacing-xl) var(--spacing-md)}}@media (max-width: 480px){.admin-sidebar{width:260px}.admin-content{padding:var(--spacing-lg) var(--spacing-sm)}.mobile-header{padding:var(--spacing-sm) var(--spacing-md)}.mobile-header-title{font-size:var(--font-size-base)}}.custom-select{position:relative;width:100%}.custom-select.disabled{opacity:.6;cursor:not-allowed}.custom-select__trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);background:var(--color-bg-darker);border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all var(--transition-base)}.custom-select__trigger:hover:not(.disabled){border-color:var(--color-text-muted)}.custom-select__trigger:focus,.custom-select__trigger.open{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}.custom-select.has-value .custom-select__trigger{background-color:#d4af371a;border-color:var(--color-secondary)}.custom-select.error .custom-select__trigger{border-color:var(--color-error)}.custom-select.disabled .custom-select__trigger{cursor:not-allowed}.custom-select__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select__value.placeholder{color:var(--color-text-muted)}.custom-select__arrow{flex-shrink:0;transition:transform var(--transition-base)}.custom-select__trigger.open .custom-select__arrow{transform:rotate(180deg)}.custom-select__options{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:1000;list-style:none;margin:0;padding:0;max-height:300px;overflow-y:auto;background-color:#1a1d2e;border:2px solid var(--color-secondary);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg),0 0 20px #d4af374d;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.custom-select__options::-webkit-scrollbar{width:8px}.custom-select__options::-webkit-scrollbar-track{background:var(--color-bg-card);border-radius:var(--radius-sm)}.custom-select__options::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}.custom-select__options::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.custom-select__option{display:block;padding:var(--spacing-sm) var(--spacing-md);background-color:#1a1d2e;font-family:var(--font-primary);font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base)}.custom-select__option:hover,.custom-select__option.focused{background-color:#2a2f4a}.custom-select__option.selected{background-color:#2e3348;border-left:3px solid var(--color-secondary);padding-left:calc(var(--spacing-md) - 3px);font-weight:var(--font-weight-semibold)}.custom-select__option:active{background-color:#232842}.option-label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.option-description{font-weight:var(--font-weight-normal);color:var(--color-text-muted);font-size:var(--font-size-sm)}@media (max-width: 480px){.custom-select__options{max-height:200px}.custom-select__option{padding:var(--spacing-xs) var(--spacing-sm)}}.contact-form-backdrop{position:fixed;inset:0;background-color:#000c;overflow-y:auto;overflow-x:hidden;z-index:var(--z-modal-backdrop);animation:fadeInBackdrop .2s ease-out;padding:var(--spacing-lg) var(--spacing-md);-webkit-overflow-scrolling:touch}.contact-form-modal{width:100%;max-width:600px;max-height:calc(100vh - 2rem);background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),var(--glow-primary);animation:slideInModal .3s ease-out;z-index:var(--z-modal);margin:auto;display:flex;flex-direction:column;overflow:hidden}.contact-form-header{display:flex;align-items:center;gap:var(--spacing-sm);position:relative;padding:var(--spacing-lg);border-bottom:2px solid var(--color-border);flex-shrink:0}.contact-form-header h2{font-size:var(--font-size-2xl);color:var(--color-heading);text-shadow:var(--glow-secondary);margin:0;flex:1}.contact-form-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-base)}.contact-form-close:hover:not(:disabled){color:var(--color-text-primary);background-color:#ffffff1a}.contact-form-close:disabled{opacity:.5;cursor:not-allowed}.contact-form-success,.contact-form-error{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);margin:0 0 var(--spacing-md) 0;border-radius:var(--radius-sm);animation:slideInMessage .3s ease-out;flex-shrink:0}@keyframes slideInMessage{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.contact-form-success{background:#2ed57326;border:2px solid var(--color-success);color:var(--color-success)}.contact-form-error{background:#ff4a6e26;border:2px solid var(--color-error);color:var(--color-error)}.contact-form-success p,.contact-form-error p{margin:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:var(--line-height-relaxed);word-wrap:break-word;overflow-wrap:break-word}.contact-form{padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);overflow-y:auto;overflow-x:hidden}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em}.form-group .required{color:var(--color-error)}.form-group input,.form-group select,.form-group textarea{background:var(--color-bg-darker);border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-base)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--color-error)}.form-group textarea{resize:vertical;min-height:120px;line-height:var(--line-height-relaxed)}.form-group select{cursor:pointer;background-color:var(--color-bg-darker);color-scheme:dark}.form-group select:not([value=""]):valid,.form-group select.has-value{background-color:#d4af371a;border-color:var(--color-secondary)}.form-group select option{background-color:var(--color-bg-darker)!important;background:var(--color-bg-darker)!important;color:var(--color-text-primary)!important;padding:var(--spacing-sm)}.form-group select option:hover,.form-group select option:focus,.form-group select option:checked{background-color:#d4af3733!important;background:#d4af3733!important;color:var(--color-text-primary)!important}@-moz-document url-prefix(){.form-group select option{background-color:#1a1a2e!important;color:#e0e0e0!important}}.category-description{font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic;margin:0}.error-message{font-size:var(--font-size-sm);color:var(--color-error);margin:0;display:flex;align-items:center;gap:var(--spacing-xs)}.error-message:before{content:"⚠"}.contact-form-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-sm);border-top:2px solid var(--color-border);margin-top:var(--spacing-sm);flex-shrink:0}.button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base)}.button:disabled{opacity:.6;cursor:not-allowed}.button--secondary:hover:not(:disabled){background-color:#ffffff1a;border-color:var(--color-text-primary)}.button--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-primary)}.button--primary:active:not(:disabled){transform:translateY(0)}.loading-spinner{width:18px;height:18px;border:3px solid rgba(0,0,0,.3);border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.contact-form-modal{max-width:100%;margin:0;border-radius:0;min-height:100vh}.contact-form-backdrop{padding:0}}@media (max-width: 480px){.contact-form-header{padding:var(--spacing-lg)}.contact-form{padding:var(--spacing-lg);gap:var(--spacing-md)}.contact-form-footer{flex-direction:column;gap:var(--spacing-sm)}.button{width:100%}}.public-layout{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg-primary)}.public-nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:#1e1e2ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:all var(--transition-base)}.public-nav.scrolled{border-bottom-color:var(--color-border);box-shadow:var(--shadow-lg)}.nav-container{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:var(--spacing-md) var(--spacing-lg)}.nav-brand{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:var(--color-secondary);font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);transition:all var(--transition-fast)}.nav-brand:hover{transform:scale(1.05);text-shadow:var(--glow-secondary)}.brand-text{color:var(--color-secondary);font-weight:var(--font-weight-bold)}.nav-links{display:flex;align-items:center;gap:var(--spacing-xs)}.nav-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.nav-link:hover{color:var(--color-text-primary);background:#ffffff0d}.nav-link.active{color:var(--color-secondary);background:#ffd7001a}.admin-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);text-decoration:none;color:var(--color-text-muted);font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.admin-link:hover{color:var(--color-primary);border-color:var(--color-primary)}.mobile-menu-toggle{display:none;background:transparent;border:none;color:var(--color-text-primary);cursor:pointer;padding:var(--spacing-xs)}.nav-links-mobile{display:none;flex-direction:column;padding:var(--spacing-md);border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.nav-links-mobile .nav-link{padding:var(--spacing-md);font-size:var(--font-size-lg)}.nav-links-mobile .admin-mobile{color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-top:var(--spacing-sm);padding-top:var(--spacing-md)}.desktop-only{display:flex}.public-main{flex:1;margin-top:72px}.public-footer{background:var(--color-bg-secondary);border-top:2px solid var(--color-border);padding:var(--spacing-2xl) 0 var(--spacing-xl) 0;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xl)}.footer-contact-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-2xl);background:var(--color-secondary);border:2px solid var(--color-secondary-light);border-radius:var(--radius-md);color:var(--color-primary-dark);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 12px #d4af374d}.footer-contact-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #d4af3780,var(--glow-primary)}.footer-contact-button:active{transform:translateY(-1px)}.footer-links{display:flex;gap:var(--spacing-2xl);flex-wrap:wrap;justify-content:center;align-items:center}.footer-links a{color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);transition:all var(--transition-fast);position:relative}.footer-links a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-secondary);transition:width var(--transition-fast)}.footer-links a:hover{color:var(--color-secondary)}.footer-links a:hover:after{width:100%}.footer-copyright{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.footer-copyright p{margin:0}.icons8-link{color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-semibold);transition:all var(--transition-fast)}.icons8-link:hover{color:var(--color-secondary-light);text-decoration:underline}.success-toast{position:fixed;bottom:var(--spacing-2xl);right:var(--spacing-2xl);display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-success);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-xl),0 0 20px #2ed57366;z-index:10000;animation:slideInToast .3s ease-out}@media (max-width: 768px){.desktop-only{display:none!important}.mobile-menu-toggle{display:block}.nav-links-mobile{display:flex}.public-main{margin-top:64px}.nav-container{padding:var(--spacing-sm) var(--spacing-md)}.footer-links{gap:var(--spacing-lg);font-size:var(--font-size-base)}.footer-contact-button{width:100%;max-width:300px}.success-toast{bottom:var(--spacing-lg);right:var(--spacing-lg);left:var(--spacing-lg)}}@media (max-width: 480px){.footer-links{flex-direction:column;gap:var(--spacing-md)}.footer-copyright{font-size:var(--font-size-xs)}}.login-page{min-height:100vh;width:100%;display:flex;justify-content:center;align-items:center;padding:var(--spacing-md);background:var(--color-bg-primary);overflow:hidden;position:relative}.login-background{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(74,158,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(212,175,55,.1) 0%,transparent 50%);z-index:var(--z-background);pointer-events:none}.login-card{width:100%;max-width:450px;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--spacing-2xl);position:relative;z-index:var(--z-content);animation:fadeIn .6s ease-out,pulseGlow 3s ease-in-out infinite}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-title{font-size:var(--font-size-3xl);color:var(--color-heading);margin-top:var(--spacing-md);margin-bottom:var(--spacing-xs);text-shadow:var(--glow-primary);letter-spacing:var(--letter-spacing-wide)}.login-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);font-style:italic}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:var(--letter-spacing-tight);display:flex;align-items:center;gap:var(--spacing-xs)}.password-input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;padding:var(--spacing-md);padding-right:calc(var(--spacing-md) + 40px);font-size:var(--font-size-base);background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:2px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-base)}.form-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:var(--glow-focus)}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input::placeholder{color:var(--color-text-muted);font-style:italic}.password-toggle{position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%);background:none;border:none;padding:var(--spacing-xs);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.password-toggle:hover:not(:disabled){color:var(--color-text-primary);background-color:#ffffff1a}.password-toggle:disabled{opacity:.4;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:#ff4a6e1a;border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);font-size:var(--font-size-sm);animation:fadeIn .3s ease-out}.submit-button{width:100%;padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);font-family:var(--font-heading);letter-spacing:var(--letter-spacing-normal);background:linear-gradient(135deg,var(--color-secondary-dark),var(--color-secondary));color:var(--color-primary-dark);border:2px solid var(--color-secondary-light);border-radius:var(--radius-sm);box-shadow:var(--shadow-md),var(--glow-secondary);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);cursor:pointer;transition:all var(--transition-base)}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--glow-primary-strong);border-color:var(--color-secondary-light)}.submit-button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner{width:20px;height:20px;border:3px solid rgba(0,0,0,.3);border-top-color:var(--color-primary-dark);border-radius:50%;animation:spin .8s linear infinite}.login-footer{margin-top:var(--spacing-xl);text-align:center}.login-note{font-size:var(--font-size-sm);color:var(--color-text-muted);font-style:italic;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}@media (max-width: 768px){.login-card{padding:var(--spacing-xl);max-width:400px}.login-title{font-size:var(--font-size-2xl)}}@media (max-width: 480px){.login-page{padding:var(--spacing-sm)}.login-card{padding:var(--spacing-lg)}.login-title{font-size:var(--font-size-xl)}.submit-button{font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md)}}.placeholder-page{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-lg);animation:fadeIn .4s ease-out}.placeholder-header{text-align:center;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-xl);border-bottom:2px solid var(--color-border)}.placeholder-header h1{margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm);text-shadow:var(--glow-primary)}.placeholder-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);font-style:italic}.placeholder-content{display:flex;flex-direction:column;gap:var(--spacing-lg);font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.placeholder-content p{color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.info-box{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-card);text-align:center}.info-box h2{color:var(--color-heading);font-size:var(--font-size-2xl);margin-top:var(--spacing-md);margin-bottom:var(--spacing-lg);text-shadow:var(--glow-secondary)}.info-box p{color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.feature-list{list-style:none;padding:0;margin:var(--spacing-lg) 0;text-align:left}.feature-list li{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.feature-list li:hover{background-color:#ffffff0d}.feature-list strong{color:var(--color-secondary)}.status-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,#00d4ff33,#4a9eff33);border:2px solid var(--color-accent);border-radius:var(--radius-md);color:var(--color-accent-light);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);box-shadow:var(--glow-accent);margin:var(--spacing-xl) auto 0}@media (max-width: 768px){.placeholder-page{padding:var(--spacing-xl) var(--spacing-md)}.placeholder-header h1{font-size:var(--font-size-2xl)}.placeholder-subtitle{font-size:var(--font-size-base)}.info-box{padding:var(--spacing-lg)}.info-box h2{font-size:var(--font-size-xl)}}@media (max-width: 480px){.placeholder-page{padding:var(--spacing-lg) var(--spacing-sm)}.placeholder-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.info-box{padding:var(--spacing-md)}.feature-list li{padding:var(--spacing-xs) var(--spacing-sm)}.status-badge{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}}.character-stats-page{max-width:1000px;margin:0 auto;padding:var(--spacing-xl)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border)}.header-left{display:flex;align-items:center;gap:var(--spacing-lg)}.header-left h1{margin:0;color:var(--color-heading)}.page-subtitle{margin:var(--spacing-xs) 0 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.header-actions{display:flex;gap:var(--spacing-md)}.alert{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-weight:var(--font-weight-medium)}.alert-success{background:#4caf501a;border:2px solid var(--color-success, #4caf50);color:var(--color-success, #4caf50)}.alert-error{background:#ff4a6e1a;border:2px solid var(--color-error);color:var(--color-error)}.settings-sections{display:flex;flex-direction:column;gap:var(--spacing-xl)}.settings-section{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.settings-section h2{margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-xl)}.section-description{margin:0 0 var(--spacing-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-sm)}.form-group input,.form-group textarea{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);font-family:inherit;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ffd7001a}.form-group textarea{resize:vertical;min-height:100px}.profile-picture-upload{display:flex;align-items:center;gap:var(--spacing-xl)}.current-picture{width:150px;height:150px;border-radius:var(--radius-full);border:3px solid var(--color-border);overflow:hidden;background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center}.current-picture img{width:100%;height:100%;object-fit:cover}.no-picture{display:flex;align-items:center;justify-content:center;opacity:.5}.upload-controls{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.file-upload-btn{position:relative;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:fit-content}.file-upload-btn input[type=file]{position:absolute;opacity:0;width:0;height:0}.help-text{margin:0;color:var(--color-text-muted);font-size:var(--font-size-xs)}.array-manager{display:flex;flex-direction:column;gap:var(--spacing-md)}.add-item-form{display:flex;gap:var(--spacing-sm)}.add-item-form input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.add-item-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ffd7001a}.add-button-form{display:grid;grid-template-columns:1fr 2fr 1fr auto;gap:var(--spacing-sm)}.add-button-form input{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.add-button-form input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #ffd7001a}.items-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.list-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.list-item:hover{border-color:var(--color-secondary)}.list-item span{color:var(--color-text-primary);font-size:var(--font-size-base)}.button-item{align-items:center}.button-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.button-url{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-left:auto;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-state{margin:0;padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted);font-style:italic;background:var(--color-bg-tertiary);border:2px dashed var(--color-border);border-radius:var(--radius-md)}.btn-primary{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.btn-primary:hover:not(:disabled){background:var(--color-secondary);transform:translateY(-2px);box-shadow:var(--glow-secondary)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:var(--spacing-xs)}.btn-secondary:hover{background:var(--color-primary);color:var(--color-bg-primary);transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}.btn-icon{background:transparent;border:none;color:var(--color-error);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.btn-icon:hover{background:#ff4a6e1a}.page-footer{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:2px solid var(--color-border);display:flex;justify-content:flex-end}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl);min-height:400px}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.character-stats-page{padding:var(--spacing-lg)}.page-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.header-actions{width:100%}.header-actions button{flex:1}.form-grid{grid-template-columns:1fr}.profile-picture-upload{flex-direction:column;align-items:flex-start}.add-button-form{grid-template-columns:1fr}.button-url{max-width:150px}}@media (max-width: 480px){.character-stats-page,.settings-section{padding:var(--spacing-md)}.current-picture{width:100px;height:100px}.button-info{flex-wrap:wrap}.button-url{width:100%;max-width:100%;margin-left:0}}.tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--tag-color, var(--color-secondary));border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.tag--small{padding:2px var(--spacing-xs);font-size:var(--font-size-xs);gap:2px}.tag--normal{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.tag--large{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);gap:var(--spacing-sm)}.tag--clickable{cursor:pointer}.tag--clickable:hover{background-color:var(--tag-color);color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.tag--clickable:active{transform:translateY(0);box-shadow:none}.tag--clickable:focus{outline:2px solid var(--tag-color);outline-offset:2px}.tag-name{line-height:1.2}.tag-remove{background:none;border:none;padding:0;margin:0;cursor:pointer;display:flex;align-items:center;justify-content:center;width:18px;height:18px;min-width:18px;border-radius:50%;color:inherit;opacity:.7;transition:all var(--transition-fast)}.tag-remove:hover{opacity:1;background-color:#fff3;transform:scale(1.1)}.tag-remove:focus{outline:none;opacity:1;background-color:#ffffff4d}.tag--small .tag-remove{width:14px;height:14px;min-width:14px}.tag--large .tag-remove{width:22px;height:22px;min-width:22px}.tag-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.tag-list--compact{gap:4px}@media (max-width: 480px){.tag{font-size:var(--font-size-xs);padding:2px var(--spacing-xs)}.tag--large{font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-sm)}}.modal-backdrop{position:fixed;inset:0;background-color:#000000bf;display:flex;justify-content:center;align-items:center;z-index:var(--z-modal-backdrop);animation:fadeInBackdrop .2s ease-out;padding:var(--spacing-md)}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}.modal-content{width:100%;max-width:450px;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),var(--glow-primary);animation:slideInModal .3s ease-out;z-index:var(--z-modal)}.modal-content--danger{border-color:var(--color-error);box-shadow:var(--shadow-xl),0 0 30px #ff4a6e4d}.modal-content--warning{border-color:var(--color-warning);box-shadow:var(--shadow-xl),0 0 30px #d4af374d}.modal-header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-xl) var(--spacing-md);border-bottom:1px solid var(--color-border)}.modal-title{font-size:var(--font-size-xl);color:var(--color-heading);text-shadow:var(--glow-secondary);text-align:center;margin:0}.modal-content--danger .modal-title{color:var(--color-error)}.modal-content--warning .modal-title{color:var(--color-warning)}.modal-body{padding:var(--spacing-lg) var(--spacing-xl);text-align:center}.modal-message{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:var(--line-height-relaxed);margin:0}.modal-footer{display:flex;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-xl) var(--spacing-xl);border-top:1px solid var(--color-border)}.modal-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);min-width:120px;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base)}.modal-button:disabled{opacity:.6;cursor:not-allowed}.modal-button--cancel{background:transparent;border:2px solid var(--color-text-muted);color:var(--color-text-primary)}.modal-button--cancel:hover:not(:disabled){background-color:#ffffff1a;border-color:var(--color-text-primary)}.modal-button--confirm{background:var(--color-secondary);border:2px solid var(--color-secondary-light);color:var(--color-primary-dark)}.modal-button--confirm:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-primary)}.modal-button--confirm:active:not(:disabled){transform:translateY(0)}.modal-button--danger{background:var(--color-error);border:2px solid #ff6b8a;color:#fff}.modal-button--danger:hover:not(:disabled){box-shadow:0 0 20px #ff4a6e80}.modal-button--warning{background:var(--color-warning);border:2px solid var(--color-secondary-light);color:var(--color-primary-dark)}.modal-button--warning:hover:not(:disabled){box-shadow:0 0 20px #d4af3780}.modal-button .loading-spinner{width:18px;height:18px;border:3px solid rgba(0,0,0,.3);border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 480px){.modal-content{max-width:100%}.modal-footer{flex-direction:column;gap:var(--spacing-sm)}.modal-button{width:100%}.modal-header{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-sm)}.modal-body{padding:var(--spacing-md) var(--spacing-lg)}.modal-footer{padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-lg)}}.projects-page{padding:2rem;max-width:1400px;margin:0 auto}.projects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.project-card{background:var(--card-background, #fff);border:1px solid var(--border-color, #e1e8ed);border-radius:8px;padding:1.5rem;transition:transform .2s,box-shadow .2s}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-card-header h3{margin:0;font-size:1.25rem;flex:1}.project-actions{display:flex;gap:.5rem}.project-meta{display:flex;gap:.5rem;margin-bottom:1rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status-planning{background:#e8f4f8;color:#0288d1}.status-active{background:#e3f2fd;color:#1976d2}.status-completed{background:#e8f5e9;color:#388e3c}.status-on_hold{background:#fff3e0;color:#f57c00}.status-archived{background:#f5f5f5;color:#757575}.project-description{color:var(--text-secondary, #666);margin:1rem 0;line-height:1.5}.project-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.tag-selector{width:100%}.selected-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.tag-search-wrapper{position:relative}.tag-search-input{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.tag-search-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px #bb86fc33}.tag-search-input input{flex:1;background:transparent;border:none;color:var(--color-text-primary);font-size:var(--font-size-base);outline:none}.tag-search-input input::placeholder{color:var(--color-text-muted)}.tag-search-input input:disabled{opacity:.6}.tag-loading-spinner{width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin 1s linear infinite}.tag-suggestions{position:absolute;top:calc(100% + var(--spacing-xs));left:0;right:0;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;max-height:300px;overflow-y:auto}.suggestions-list{padding:var(--spacing-xs)}.suggestion-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);text-align:left;cursor:pointer;transition:all var(--transition-fast)}.suggestion-item:hover{background:#ffffff0d}.suggestion-color{width:16px;height:16px;border-radius:var(--radius-xs);flex-shrink:0}.suggestion-name{flex:1}.suggestion-item svg{color:var(--color-text-muted);opacity:0;transition:opacity var(--transition-fast)}.suggestion-item:hover svg{opacity:1;color:var(--color-secondary)}.create-tag-section{padding:var(--spacing-md);border-top:1px solid var(--color-border);background:#ffffff05}.create-tag-header{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-secondary);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.create-tag-options{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.color-picker-preset{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.color-picker-preset label{font-weight:var(--font-weight-medium)}.preset-colors{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.preset-color-btn{width:28px;height:28px;border:2px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.preset-color-btn:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000004d}.preset-color-btn.selected{border-color:#fff;box-shadow:0 0 0 2px var(--color-secondary);transform:scale(1.1)}.color-preview{width:20px;height:20px;border-radius:var(--radius-xs);border:1px solid rgba(255,255,255,.2)}.create-tag-button{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-secondary);color:var(--color-primary-dark);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.create-tag-button:hover{transform:translateY(-1px);box-shadow:var(--glow-secondary)}.create-tag-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.no-suggestions{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--color-text-muted);font-size:var(--font-size-sm)}@media (max-width: 480px){.create-tag-options{flex-direction:column;align-items:stretch}.color-picker{justify-content:center}.create-tag-button{width:100%}}.project-form-container{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.project-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.project-form-header h1{margin:0;text-shadow:var(--glow-primary)}.project-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.devlogs-page{padding:2rem;max-width:1400px;margin:0 auto}.devlogs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.devlogs-filters{display:flex;gap:1rem;margin-bottom:2rem}.devlogs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.devlog-card{background:var(--card-background, #fff);border:1px solid var(--border-color, #e1e8ed);border-radius:8px;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.devlog-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.devlog-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.devlog-card-header h3{margin:0;font-size:1.25rem;flex:1}.devlog-actions{display:flex;gap:.5rem}.devlog-meta{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem}.session-date{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary, #666);background:var(--background-secondary, #f5f5f5);padding:.25rem .75rem;border-radius:12px}.devlog-project{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--background-tertiary, #fafafa);border-radius:6px;margin-bottom:1rem;font-size:.875rem;color:var(--text-primary, #333)}.devlog-project svg{flex-shrink:0}.devlog-content{color:var(--text-secondary, #666);margin:1rem 0;line-height:1.5;flex:1}.devlog-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color, #e1e8ed)}.devlog-tags{display:flex;gap:.5rem;flex-wrap:wrap;flex:1}.devlog-quests{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary, #666);padding:.25rem .75rem;background:var(--background-secondary, #f5f5f5);border-radius:12px}.quest-count{font-weight:500}.more-tags{font-size:.875rem;color:var(--text-secondary, #666)}.visibility-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.visibility-public{background:#e8f5e9;color:#388e3c}.visibility-private{background:#fce4ec;color:#c2185b}.devlog-form-container{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.devlog-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.devlog-form-header h1{margin:0;text-shadow:var(--glow-primary)}.devlog-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.field-hint{display:block;margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted)}.checkbox-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:300px;overflow-y:auto;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-input)}.checkbox-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background-color .2s}.checkbox-item:hover{background:var(--color-bg-hover, rgba(0, 0, 0, .05))}.checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;flex-shrink:0}.checkbox-label{flex:1;cursor:pointer;-webkit-user-select:none;user-select:none}.empty-message{color:var(--color-text-muted);font-style:italic;text-align:center;padding:var(--spacing-md);margin:0}.pages-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.pages-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.pages-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.pages-title-section h1{margin:0;text-shadow:var(--glow-primary)}.pages-subtitle{color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0;font-size:var(--font-size-base)}.pages-filters{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-wrap:wrap;gap:var(--spacing-md)}.filter-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.pages-count{color:var(--color-text-muted);font-size:var(--font-size-sm)}.pages-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.page-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.page-item:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md)}.page-type-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);min-width:80px;border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.page-info{flex:1;min-width:0}.page-title{margin:0 0 var(--spacing-xs);font-size:var(--font-size-lg);color:var(--color-heading);cursor:pointer;transition:all var(--transition-fast)}.page-title:hover{color:var(--color-secondary);text-shadow:var(--glow-secondary)}.page-title:focus{outline:2px solid var(--color-secondary);outline-offset:2px;border-radius:var(--radius-sm)}.page-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-muted)}.page-date,.page-visibility{display:flex;align-items:center;gap:var(--spacing-xs)}.page-visibility.public{color:var(--color-success)}.page-visibility.private{color:var(--color-warning)}.page-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.page-actions{display:flex;gap:var(--spacing-xs)}@media (max-width: 768px){.pages-container{padding:var(--spacing-md)}.pages-header{flex-direction:column;align-items:stretch}.pages-title-section,.create-button{justify-content:center}.pages-filters{flex-direction:column;align-items:stretch}.filter-group{justify-content:center}.pages-count{text-align:center}.page-item{flex-direction:column;align-items:stretch;text-align:center}.page-type-badge{flex-direction:row;justify-content:center;min-width:auto}.page-meta,.page-tags,.page-actions{justify-content:center}}@media (max-width: 480px){.filter-buttons{width:100%;justify-content:center}.filter-button{flex:1;justify-content:center;min-width:60px}.page-title{font-size:var(--font-size-base)}}.page-form-container{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.page-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.page-form-header h1{margin:0;text-shadow:var(--glow-primary)}.page-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-textarea{width:100%;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);font-family:Fira Code,Source Code Pro,monospace;line-height:1.6;resize:vertical;min-height:300px;transition:all var(--transition-fast)}.type-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}@media (min-width: 768px){.type-selector{grid-template-columns:repeat(4,1fr)}}.visibility-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.visibility-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.visibility-option:hover{border-color:var(--color-border-light)}.visibility-option.selected{border-color:var(--color-secondary);background:#ffd7001a}.visibility-label{font-weight:var(--font-weight-semibold)}.visibility-description{font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.quest-selector{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:300px;overflow-y:auto;padding:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.quest-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.quest-option:hover{background:#ffffff0d}.quest-option input[type=checkbox]{display:none}.quest-checkbox{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-xs);transition:all var(--transition-fast);flex-shrink:0;position:relative}.quest-checkbox:after{content:"✓";font-size:14px;font-weight:700;color:var(--color-primary-dark);opacity:0;transform:scale(0);transition:all var(--transition-fast)}.quest-option input[type=checkbox]:checked+.quest-checkbox{background:var(--color-secondary);border-color:var(--color-secondary)}.quest-option input[type=checkbox]:checked+.quest-checkbox:after{opacity:1;transform:scale(1)}.quest-title{flex:1;color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.quest-status{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff0d;border-radius:var(--radius-xs)}.no-quests-message{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--color-bg-tertiary);border:1px dashed var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);text-align:center}@media (max-width: 768px){.page-form-container{padding:var(--spacing-md)}.page-form-header{flex-direction:column;text-align:center}.type-selector{grid-template-columns:1fr 1fr}.visibility-selector,.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.cancel-button,.save-button{width:100%;justify-content:center}}@media (max-width: 480px){.type-selector{grid-template-columns:1fr}.form-section{padding:var(--spacing-md)}.form-textarea{min-height:200px}}.loading-issues{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--color-text-secondary)}.no-issues-message{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--color-bg-tertiary);border-radius:var(--radius-md);text-align:center;color:var(--color-text-secondary)}.issues-work-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.issues-help-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--spacing-md);padding:var(--spacing-sm);background:#f1c40f1a;border-radius:var(--radius-sm);border-left:3px solid var(--color-secondary)}.issue-work-item{background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);transition:all var(--transition-fast)}.issue-work-item:hover{border-color:var(--color-border-light)}.issue-work-item.selected{border-color:var(--color-secondary);background:#f1c40f0d}.issue-work-header{display:flex;align-items:flex-start;gap:var(--spacing-md)}.issue-select-checkbox{display:flex;align-items:center;cursor:pointer}.issue-select-checkbox input{display:none}.checkbox-mark{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative}.checkbox-mark:after{content:"✓";font-size:14px;font-weight:700;color:var(--color-primary-dark);opacity:0;transform:scale(0);transition:all var(--transition-fast)}.issue-select-checkbox input:checked+.checkbox-mark{background:var(--color-secondary);border-color:var(--color-secondary)}.issue-select-checkbox input:checked+.checkbox-mark:after{opacity:1;transform:scale(1)}.issue-work-info{flex:1}.issue-work-title{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-xs)}.issue-type-badge.quest{background:#9b59b6;color:#fff}.issue-new-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);background:var(--color-secondary);color:var(--color-primary-dark);text-transform:uppercase;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.issue-work-item.is-new{border-left:3px solid var(--color-secondary);background:#ffd7000d}.issue-title-text{font-weight:var(--font-weight-semibold);color:var(--color-heading)}.issue-work-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:1.4}.issue-work-details{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--spacing-md)}.issue-status-change,.issue-work-notes{display:flex;flex-direction:column;gap:var(--spacing-xs)}.status-label,.notes-label{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-primary)}.status-select{padding:var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.status-select:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #f1c40f33}.work-notes-textarea{padding:var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);resize:vertical;min-height:80px;transition:all var(--transition-fast)}.work-notes-textarea:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #f1c40f33}.work-notes-textarea::placeholder{color:var(--color-text-muted)}@media (max-width: 768px){.issue-work-header{flex-direction:column}.issue-work-title{justify-content:center}.issue-work-description{text-align:center}}.page-view-container{width:100%;max-width:1000px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.page-view-header{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.page-type-badge-large{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);color:#fff;font-weight:var(--font-weight-semibold);text-transform:uppercase;font-size:var(--font-size-sm)}.page-title{flex:1;margin:0;color:var(--color-heading);text-shadow:var(--glow-primary);font-size:var(--font-size-2xl)}.page-actions{display:flex;gap:var(--spacing-sm);margin-left:auto}.action-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);box-sizing:border-box;white-space:nowrap}.action-button .icon{flex-shrink:0}.page-meta-section{display:flex;flex-wrap:wrap;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.visibility-badge{font-weight:var(--font-weight-semibold);text-transform:uppercase}.visibility-badge.public{color:var(--color-success)}.visibility-badge.private{color:var(--color-warning)}.page-tags-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.page-tags-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.project-details-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.project-details-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.project-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.project-info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;font-weight:var(--font-weight-medium)}.info-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.info-value.status{color:var(--color-secondary)}.linked-quests-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.linked-quests-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.quests-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.quest-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-sm)}.quest-item .quest-title{flex:1;color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.quest-item .quest-status{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff0d;border-radius:var(--radius-xs);text-transform:capitalize}.page-content-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg)}.page-content-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.content-body{color:var(--color-text-primary);line-height:1.7;font-size:var(--font-size-base)}.content-body p{margin:0 0 var(--spacing-md)}.content-body p:last-child{margin-bottom:0}.content-body h1{font-size:var(--font-size-2xl);color:var(--color-heading);margin:var(--spacing-lg) 0 var(--spacing-md)}.content-body h2{font-size:var(--font-size-xl);color:var(--color-heading);margin:var(--spacing-lg) 0 var(--spacing-md)}.content-body h3{font-size:var(--font-size-lg);color:var(--color-heading);margin:var(--spacing-md) 0 var(--spacing-sm)}.content-body strong{color:var(--color-text-primary);font-weight:var(--font-weight-bold)}.content-body em{font-style:italic}.content-body code{background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-xs);font-family:Fira Code,Source Code Pro,monospace;font-size:.9em;color:var(--color-secondary)}.content-body pre{background:var(--color-bg-tertiary);padding:var(--spacing-md);border-radius:var(--radius-sm);overflow-x:auto;margin:var(--spacing-md) 0}.content-body pre code{background:transparent;padding:0;color:var(--color-text-primary)}.no-content{color:var(--color-text-muted);font-style:italic;text-align:center;padding:var(--spacing-lg)}@media (max-width: 768px){.page-view-container{padding:var(--spacing-md)}.page-view-header{flex-direction:column;align-items:stretch}.page-title{text-align:center;font-size:var(--font-size-xl)}.page-actions{justify-content:center;margin-left:0}.page-type-badge-large{justify-content:center}.back-button-small{position:absolute;top:var(--spacing-md);left:var(--spacing-md)}.page-meta-section{flex-direction:column;gap:var(--spacing-sm)}.meta-item{justify-content:center}}@media (max-width: 480px){.action-button span{display:none}.action-button{padding:var(--spacing-sm)}.project-info-grid{grid-template-columns:1fr}}.devlog-issues-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.devlog-issues-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);font-size:var(--font-size-lg);color:var(--color-heading);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-secondary)}.devlog-issues-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.devlog-issue-item{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-md)}.devlog-issue-header{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-sm)}.issue-type-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase}.issue-type-badge.bug{background:#e74c3c;color:#fff}.issue-type-badge.improvement{background:#3498db;color:#fff}.issue-severity-badge{padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#fff;text-transform:uppercase}.devlog-issue-title{font-weight:var(--font-weight-semibold);color:var(--color-heading)}.devlog-issue-status{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.devlog-issue-status .status-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.devlog-issue-status .status-value{padding:2px 8px;background:var(--color-secondary);color:var(--color-primary-dark);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase}.devlog-issue-notes{background:#f1c40f1a;border-left:3px solid var(--color-secondary);padding:var(--spacing-sm);border-radius:var(--radius-sm);margin-bottom:var(--spacing-sm)}.devlog-issue-notes .notes-label{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs)}.devlog-issue-notes .notes-content{margin:0;font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5;white-space:pre-wrap}.devlog-issue-description{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;font-style:italic}@media (max-width: 768px){.devlog-issue-header,.devlog-issue-status{justify-content:center}}.quests-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.quests-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.quests-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.quests-title-section h1{margin:0;text-shadow:var(--glow-primary)}.quests-subtitle{color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0;font-size:var(--font-size-base)}.create-button:active{transform:translateY(0)}.quests-filters{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.filter-group{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.filter-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);min-width:60px}.filter-buttons{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.filter-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.filter-button:hover{background:#ffffff0d;border-color:var(--color-border-light);color:var(--color-text-primary)}.filter-button.active{background:var(--color-secondary);border-color:var(--color-secondary-light);color:var(--color-primary-dark);font-weight:var(--font-weight-semibold)}.quests-count{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:right;margin-top:var(--spacing-xs)}.retry-button{margin-left:auto;padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.retry-button:hover{background:var(--color-error);color:#fff}.quests-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.quest-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.quest-item:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md)}.quest-type-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);min-width:90px;border-radius:var(--radius-sm);color:var(--color-primary-dark);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.quest-info{flex:1;min-width:0}.quest-title{margin:0 0 var(--spacing-xs);font-size:var(--font-size-lg);color:var(--color-heading);cursor:pointer;transition:all var(--transition-fast)}.quest-title:hover{color:var(--color-secondary);text-shadow:var(--glow-secondary)}.quest-title:focus{outline:2px solid var(--color-secondary);outline-offset:2px;border-radius:var(--radius-sm)}.quest-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);align-items:center;flex-wrap:wrap}.quest-status-badge{padding:var(--spacing-xs) var(--spacing-sm);border:2px solid;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.quest-date{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted)}.quest-progress{margin-bottom:var(--spacing-sm)}.progress-bar{width:100%;height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--spacing-xs)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-secondary-dark),var(--color-secondary));border-radius:var(--radius-sm);transition:width .3s ease}.progress-text{font-size:var(--font-size-xs);color:var(--color-text-muted)}.quest-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.more-tags{font-size:var(--font-size-xs);color:var(--color-text-muted);font-style:italic}.quest-actions{display:flex;gap:var(--spacing-xs)}.action-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.action-button:hover{border-color:var(--color-border-light);color:var(--color-text-primary)}@media (max-width: 768px){.quests-container{padding:var(--spacing-md)}.quests-header{flex-direction:column;align-items:stretch}.quests-title-section,.create-button{justify-content:center}.quests-filters{align-items:stretch}.filter-group{justify-content:center;flex-direction:column;align-items:stretch}.filter-label{text-align:center;min-width:auto}.filter-buttons{justify-content:center}.quests-count{text-align:center}.quest-item{flex-direction:column;align-items:stretch;text-align:center}.quest-type-badge{flex-direction:row;justify-content:center;min-width:auto}.quest-meta,.quest-tags,.quest-actions{justify-content:center}}@media (max-width: 480px){.filter-buttons{width:100%}.filter-button{flex:1;justify-content:center;min-width:80px}.quest-title{font-size:var(--font-size-base)}}.quest-form-container{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.quest-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.quest-form-header h1{margin:0;text-shadow:var(--glow-primary)}.quest-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-textarea{width:100%;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);line-height:1.6;resize:vertical;min-height:150px;transition:all var(--transition-fast)}.form-textarea.error{border-color:var(--color-error)}.form-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--spacing-md)}.add-subquest-input{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.add-subquest-input input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.add-subquest-input input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #bb86fc33}.add-subquest-input input::placeholder{color:var(--color-text-muted)}.add-subquest-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-secondary);border:none;border-radius:var(--radius-sm);color:var(--color-primary-dark);cursor:pointer;transition:all var(--transition-fast)}.add-subquest-button:hover{transform:translateY(-1px);box-shadow:var(--glow-secondary)}.add-subquest-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.subquest-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:grab}.subquest-item:active{cursor:grabbing}.subquest-item.dragging{opacity:.5;background:#bb86fc33;border:1px dashed var(--color-primary)}.subquest-checkbox{display:flex;align-items:center;cursor:pointer}.subquest-checkbox input{display:none}.checkbox-custom{display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-xs);transition:all var(--transition-fast);position:relative}.checkbox-custom:after{content:"✓";font-size:14px;font-weight:700;color:var(--color-primary-dark);opacity:0;transform:scale(0);transition:all var(--transition-fast)}.subquest-checkbox input:checked+.checkbox-custom{background:var(--color-secondary);border-color:var(--color-secondary)}.subquest-checkbox input:checked+.checkbox-custom:after{opacity:1;transform:scale(1)}.subquest-title{flex:1;color:var(--color-text-primary)}.remove-subquest-button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);border-radius:var(--radius-xs)}.remove-subquest-button:hover{background:#ff4a6e33;color:var(--color-error)}.no-subquests{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);color:var(--color-text-muted);font-size:var(--font-size-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-sm)}@media (max-width: 768px){.quest-form-container{padding:var(--spacing-md)}.quest-form-header{flex-direction:column;text-align:center}.type-selector{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.cancel-button,.save-button{width:100%;justify-content:center}}@media (max-width: 480px){.form-section{padding:var(--spacing-md)}}.quest-view-container{width:100%;max-width:1000px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.quest-view-header{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.quest-actions{display:flex;gap:var(--spacing-sm);margin-left:auto}.action-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.subquests-checklist{display:flex;flex-direction:column;gap:var(--spacing-xs)}.subquest-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.subquest-item:hover{background:#ffffff0d}.subquest-item input[type=checkbox]{display:none}.checkbox-custom{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-xs);transition:all var(--transition-fast);flex-shrink:0;position:relative}.checkbox-custom:after{content:"✓";font-size:16px;font-weight:700;color:var(--color-primary-dark);opacity:0;transform:scale(0);transition:all var(--transition-fast)}.subquest-item input[type=checkbox]:checked+.checkbox-custom{background:var(--color-secondary);border-color:var(--color-secondary)}.subquest-item input[type=checkbox]:checked+.checkbox-custom:after{opacity:1;transform:scale(1)}.quest-pages-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg)}@media (max-width: 768px){.quest-view-container{padding:var(--spacing-md)}.quest-view-header{flex-direction:column;align-items:stretch}.quest-title{text-align:center;font-size:var(--font-size-xl)}.quest-actions{justify-content:center;margin-left:0}.quest-type-badge-large{justify-content:center}.back-button-small{position:absolute;top:var(--spacing-md);left:var(--spacing-md)}.quest-status-section{flex-direction:column;text-align:center}.quest-meta-info{flex-direction:column;gap:var(--spacing-sm)}.meta-item{justify-content:center}}@media (max-width: 480px){.action-button span{display:none}.action-button{padding:var(--spacing-sm)}.progress-stats{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.issues-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.issues-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);flex-wrap:wrap;gap:var(--spacing-md)}.issues-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.issues-title-section h1{margin:0;text-shadow:var(--glow-primary)}.issues-subtitle{color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0;font-size:var(--font-size-base)}.issues-filters{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px solid var(--color-border)}.issues-count{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:right;margin-top:var(--spacing-xs)}.issues-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.issue-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.issue-item:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md)}.issue-type-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);min-width:90px;border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.issue-info{flex:1;min-width:0}.issue-title{margin:0 0 var(--spacing-xs);font-size:var(--font-size-lg);color:var(--color-heading)}.issue-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);align-items:center;flex-wrap:wrap}.issue-status-badge{padding:var(--spacing-xs) var(--spacing-sm);border:2px solid;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.issue-severity-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#fff;text-transform:uppercase}.issue-attached{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-secondary)}.issue-date{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted)}.issue-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0;line-height:1.5}.issue-actions{display:flex;gap:var(--spacing-xs)}@media (max-width: 768px){.issues-container{padding:var(--spacing-md)}.issues-header{flex-direction:column;align-items:stretch}.issues-title-section{justify-content:center}.issue-item{flex-direction:column;align-items:stretch;text-align:center}.issue-type-badge{flex-direction:row;justify-content:center;min-width:auto}.issue-meta,.issue-actions{justify-content:center}}@media (max-width: 480px){.issue-title{font-size:var(--font-size-base)}}.issue-form-container{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.issue-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.issue-form-header h1{margin:0;text-shadow:var(--glow-primary)}.issue-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg)}.section-title{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-lg);font-size:var(--font-size-xl);color:var(--color-heading);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-secondary)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.required{color:var(--color-error)}.label-hint{font-weight:var(--font-weight-normal);font-size:var(--font-size-sm);color:var(--color-text-muted);margin-left:var(--spacing-xs)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #f1c40f33}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-error)}.form-textarea{resize:vertical;min-height:120px}.char-count{display:block;text-align:right;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.type-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.type-option:hover{border-color:var(--color-border-light);background:#ffffff0d}.type-option.selected{border-color:var(--color-secondary);background:#f1c40f1a}.type-label{font-weight:var(--font-weight-semibold);color:var(--color-heading)}.type-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.severity-selector{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.severity-option{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-weight:var(--font-weight-semibold);text-transform:uppercase;font-size:var(--font-size-sm);transition:all var(--transition-fast)}.severity-option:hover{border-color:var(--severity-color, var(--color-border-light))}.severity-option.selected{color:var(--severity-color)}.no-quests-message{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--color-bg-tertiary);border-radius:var(--radius-md);text-align:center;color:var(--color-text-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-md)}.cancel-button,.save-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-xl);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base)}.cancel-button{background:transparent;border:2px solid var(--color-border);color:var(--color-text-secondary)}.cancel-button:hover:not(:disabled){background:#ffffff0d;border-color:var(--color-border-light);color:var(--color-text-primary)}.save-button{background:linear-gradient(135deg,var(--color-secondary-dark),var(--color-secondary));border:2px solid var(--color-secondary-light);color:var(--color-primary-dark)}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-secondary)}.save-button:disabled,.cancel-button:disabled{opacity:.6;cursor:not-allowed}.button-spinner{width:20px;height:20px;border:3px solid rgba(0,0,0,.2);border-top-color:var(--color-primary-dark);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.issue-form-container{padding:var(--spacing-md)}.issue-form-header{flex-direction:column;text-align:center}.type-selector{grid-template-columns:1fr}.severity-selector{justify-content:center}.form-actions{flex-direction:column-reverse}.cancel-button,.save-button{width:100%;justify-content:center}}.inbox-page{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.inbox-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl)}.inbox-header-title{display:flex;align-items:center;gap:var(--spacing-md)}.inbox-header-title h1{font-size:var(--font-size-3xl);color:var(--color-heading);text-shadow:var(--glow-secondary);margin:0}.unread-badge{background:var(--color-error);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);min-width:24px;text-align:center}.inbox-filters{display:flex;gap:var(--spacing-md);align-items:flex-end;margin-bottom:var(--spacing-xl);flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1;min-width:200px}.filter-group label{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em}.filter-group select{background:var(--color-bg-darker);border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:var(--font-primary);font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;transition:all var(--transition-base)}.filter-group select:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #d4af3733}.refresh-button{display:flex;align-items:center;gap:var(--spacing-xs);background:var(--color-secondary);border:2px solid var(--color-secondary-light);color:var(--color-primary-dark);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-base)}.refresh-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--glow-primary)}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.inbox-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-3xl);color:var(--color-text-muted)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin .8s linear infinite}.inbox-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-3xl);color:var(--color-error);text-align:center}.inbox-error button{background:var(--color-secondary);border:2px solid var(--color-secondary-light);color:var(--color-primary-dark);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base)}.inbox-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-3xl);color:var(--color-text-muted);text-align:center}.inbox-empty h3{color:var(--color-text-primary);margin:0}.messages-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.message-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base)}.message-item:hover{border-color:var(--color-secondary);box-shadow:var(--shadow-md),var(--glow-primary);transform:translateY(-2px)}.message-item.unread{background:#3498db0d;border-color:var(--color-secondary);box-shadow:0 0 0 1px #d4af3733}.message-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-bg-darker);border:2px solid var(--color-border);border-radius:var(--radius-md);flex-shrink:0}.message-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.message-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.message-subject{font-size:var(--font-size-lg);color:var(--color-heading);margin:0}.message-item.unread .message-subject{font-weight:var(--font-weight-bold)}.message-date{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap}.message-meta{display:flex;gap:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-muted)}.message-meta span,.message-sender,.message-email{display:flex;align-items:center;gap:var(--spacing-xs)}.message-badges{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.status-badge,.category-badge{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm);border:1px solid;border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.message-actions{display:flex;align-items:center;gap:var(--spacing-xs)}.action-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-base)}.action-button:hover{transform:scale(1.1)}.action-button--delete{border-color:var(--color-error);color:var(--color-error)}.action-button--delete:hover{background:var(--color-error);color:#fff;box-shadow:0 0 15px #ff4a6e66}.message-modal-backdrop{position:fixed;inset:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-lg);overflow-y:auto}.message-modal{position:relative;width:100%;max-width:800px;max-height:90vh;background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl),var(--glow-primary);animation:slideInModal .3s ease-out;display:flex;flex-direction:column;overflow:hidden}@keyframes slideInModal{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close-button{position:absolute;top:var(--spacing-lg);right:var(--spacing-lg);background:var(--color-bg-darker);border:2px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-base);z-index:10;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.modal-close-button:hover{color:var(--color-text-primary);background-color:var(--color-error);border-color:var(--color-error);transform:scale(1.1)}.message-modal-header{padding:var(--spacing-xl);padding-right:80px;border-bottom:2px solid var(--color-border);flex-shrink:0}.sender-info{display:flex;gap:var(--spacing-md);align-items:center}.sender-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-bg-darker);border:2px solid var(--color-secondary);border-radius:var(--radius-md);flex-shrink:0;color:var(--color-secondary)}.sender-details{flex:1;min-width:0}.sender-name{font-size:var(--font-size-2xl);color:var(--color-heading);text-shadow:var(--glow-secondary);margin:0 0 var(--spacing-xs) 0;font-weight:var(--font-weight-bold)}.sender-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}.sender-email,.sender-date{display:flex;align-items:center;gap:var(--spacing-xs)}.message-modal-subject{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);background:var(--color-bg-darker);border-bottom:2px solid var(--color-border);flex-shrink:0}.subject-row{display:flex;align-items:baseline;gap:var(--spacing-sm);flex:1;min-width:0}.subject-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:var(--font-weight-semibold);white-space:nowrap}.subject-text{font-size:var(--font-size-xl);color:var(--color-heading);margin:0;font-weight:var(--font-weight-bold);overflow:hidden;text-overflow:ellipsis}.message-modal-category{padding:var(--spacing-md) var(--spacing-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.message-modal-category .category-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs)}.message-modal-body{flex:1;overflow-y:auto;padding:var(--spacing-xl);background:var(--color-bg-card)}.message-content-wrapper{background:var(--color-bg-darker);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);min-height:200px}.message-text{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:var(--line-height-relaxed);white-space:pre-wrap;word-wrap:break-word;margin:0}.message-modal-body::-webkit-scrollbar{width:10px}.message-modal-body::-webkit-scrollbar-track{background:var(--color-bg-card)}.message-modal-body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-sm)}.message-modal-body::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.message-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-xl);border-top:2px solid var(--color-border)}.button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-base)}.button--primary{background:var(--color-secondary);border:2px solid var(--color-secondary-light);color:var(--color-primary-dark)}.button--primary:hover{transform:translateY(-2px);box-shadow:var(--glow-primary)}.button--secondary{background:transparent;border:2px solid var(--color-text-muted);color:var(--color-text-primary)}.button--secondary:hover{background-color:#ffffff1a;border-color:var(--color-text-primary)}.button--danger{background:var(--color-error);border:2px solid #ff6b8a;color:#fff}.button--danger:hover{box-shadow:0 0 20px #ff4a6e80;transform:translateY(-2px)}@media (max-width: 768px){.inbox-page{padding:var(--spacing-lg)}.inbox-filters{flex-direction:column}.filter-group{min-width:100%}.message-item{flex-direction:column}.message-header{flex-direction:column;align-items:flex-start}.message-modal-footer{flex-direction:column}.button{width:100%;justify-content:center}.message-modal-subject{flex-direction:column;align-items:flex-start}.subject-row{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.sender-info{flex-direction:column;text-align:center}.sender-details{display:flex;flex-direction:column;align-items:center}.sender-meta{flex-direction:column;align-items:center;gap:var(--spacing-xs)}}@media (max-width: 480px){.inbox-header-title h1{font-size:var(--font-size-2xl)}.message-meta{flex-direction:column;gap:var(--spacing-xs)}.message-modal{margin:0;border-radius:0;min-height:100vh;max-height:100vh}.message-modal-header{padding:var(--spacing-lg);padding-right:60px}.sender-icon{width:48px;height:48px}.sender-name{font-size:var(--font-size-xl)}.subject-text{font-size:var(--font-size-lg)}.message-modal-subject,.message-modal-category{padding:var(--spacing-md) var(--spacing-lg)}.message-modal-body{padding:var(--spacing-lg)}.message-content-wrapper{padding:var(--spacing-md)}}.inventory-container{width:100%;max-width:1200px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.inventory-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-xl)}.inventory-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.inventory-title-section h1{margin:0;text-shadow:var(--glow-primary)}.inventory-subtitle{color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0}.create-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-secondary-dark),var(--color-secondary));color:var(--color-primary-dark);border:2px solid var(--color-secondary-light);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--glow-secondary)}.create-button:hover{transform:translateY(-2px);box-shadow:var(--glow-primary-strong)}.inventory-filters{display:flex;justify-content:space-between;align-items:center;background:var(--color-bg-card);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border:1px solid var(--color-border)}.filter-group{display:flex;align-items:center;gap:var(--spacing-md)}.filter-label{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.filter-buttons{display:flex;gap:var(--spacing-xs)}.filter-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.filter-button:hover{background:#ffffff0d;border-color:var(--color-border-light)}.filter-button.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-primary);box-shadow:var(--glow-primary)}.inventory-count{color:var(--color-text-muted);font-size:var(--font-size-sm)}.info-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#bb86fc1a;border:1px solid rgba(187,134,252,.3);border-radius:var(--radius-sm);color:var(--color-primary-light);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.retry-button{margin-left:auto;padding:var(--spacing-xs) var(--spacing-md);background:var(--color-error);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:opacity var(--transition-fast)}.retry-button:hover{opacity:.8}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);background:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center}.empty-state h2{color:var(--color-text-primary);margin:var(--spacing-md) 0}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.inventory-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.inventory-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:grab}.inventory-item:active{cursor:grabbing}.inventory-item:hover{border-color:var(--color-border-light);background:#ffffff05}.inventory-item.dragging{opacity:.5;background:#bb86fc1a;border:2px dashed var(--color-primary)}.drag-handle{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);padding:var(--spacing-xs);cursor:grab;opacity:.6;transition:opacity var(--transition-fast)}.drag-handle:hover{opacity:1;color:var(--color-text-primary)}.sort-order-badge{display:flex;align-items:center;justify-content:center;min-width:40px;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.item-icon-box{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border);flex-shrink:0}.item-icon-box.inventory{border-color:var(--color-secondary);background:#ffd7001a}.item-icon-box.achievement{border-color:#9b59b6;background:#9b59b61a}.item-info{flex:1;min-width:0}.item-name{margin:0;color:var(--color-heading);font-size:var(--font-size-base)}.item-title{margin:var(--spacing-xs) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.item-meta{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.item-type-badge{display:inline-flex;align-items:center;gap:4px;padding:2px var(--spacing-sm);border-radius:var(--radius-xs);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:capitalize}.item-type-badge.inventory{background:#ffd70033;color:var(--color-secondary)}.item-type-badge.achievement{background:#9b59b633;color:#9b59b6}.item-visibility{display:inline-flex;align-items:center;gap:4px;padding:2px var(--spacing-sm);border-radius:var(--radius-xs);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize}.item-visibility.public{background:#2ecc7133;color:var(--color-success)}.item-visibility.private{background:#f39c1233;color:var(--color-warning)}.item-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.more-tags{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:2px var(--spacing-xs)}.item-actions{display:flex;gap:var(--spacing-xs)}.action-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.action-button:hover{transform:translateY(-1px)}.action-button.edit:hover{background:#3498db33;border-color:#3498db;color:#3498db}.action-button.delete:hover{background:#ff4a6e33;border-color:var(--color-error);color:var(--color-error)}@media (max-width: 768px){.inventory-container{padding:var(--spacing-md)}.inventory-header{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.inventory-title-section{justify-content:center;text-align:center}.create-button{justify-content:center}.inventory-filters{flex-direction:column;gap:var(--spacing-md);align-items:stretch}.filter-group{flex-direction:column;align-items:stretch}.filter-buttons{flex-wrap:wrap;justify-content:center}.inventory-count{text-align:center}.inventory-item{flex-wrap:wrap}.item-info{width:100%;order:3}.item-actions{margin-left:auto}}@media (max-width: 480px){.inventory-item{padding:var(--spacing-sm)}.item-icon-box{width:48px;height:48px}}.inventory-form-container{width:100%;max-width:900px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.inventory-form-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.inventory-form-header h1{margin:0;text-shadow:var(--glow-primary)}.form-subtitle{color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0;font-size:var(--font-size-base)}.error-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#ff4a6e1a;border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);margin-bottom:var(--spacing-lg)}.inventory-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.form-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.section-title{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-lg);color:var(--color-heading);font-size:var(--font-size-lg)}.form-group{margin-bottom:var(--spacing-lg);position:relative}.form-group:last-child{margin-bottom:0}.form-label{display:block;color:var(--color-text-primary);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs)}.form-label .required{color:var(--color-error);margin-left:var(--spacing-xs)}.label-hint{color:var(--color-text-muted);font-weight:var(--font-weight-normal);font-size:var(--font-size-sm);margin-left:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #bb86fc33}.form-input.error{border-color:var(--color-error)}.form-input::placeholder{color:var(--color-text-muted)}.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast)}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #bb86fc33}.form-textarea{width:100%;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);line-height:1.6;resize:vertical;min-height:200px;transition:all var(--transition-fast);font-family:inherit}.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #bb86fc33}.form-textarea::placeholder{color:var(--color-text-muted)}.char-count{display:block;text-align:right;color:var(--color-text-muted);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.error-message{display:block;color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.type-selector{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.type-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);text-align:center}.type-option:hover{border-color:var(--color-border-light);transform:translateY(-2px)}.type-option.selected{border-color:var(--color-secondary);background:#ffd7001a;box-shadow:var(--glow-secondary)}.type-label{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.type-description{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.3}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:var(--spacing-sm)}.icon-option{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.icon-option:hover{border-color:var(--color-border-light);background:#ffffff0d;transform:translateY(-2px)}.icon-option.selected{border-color:var(--color-secondary);background:#ffd7001a;box-shadow:var(--glow-secondary)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg)}.cancel-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:transparent;border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.cancel-button:hover{border-color:var(--color-error);color:var(--color-error)}.cancel-button:disabled{opacity:.5;cursor:not-allowed}.save-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-xl);background:linear-gradient(135deg,var(--color-secondary-dark),var(--color-secondary));color:var(--color-primary-dark);border:2px solid var(--color-secondary-light);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--glow-secondary)}.save-button:hover{transform:translateY(-2px);box-shadow:var(--glow-primary-strong)}.save-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.button-spinner{width:20px;height:20px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--color-primary-dark);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.inventory-form-container{padding:var(--spacing-md)}.inventory-form-header{flex-direction:column;text-align:center}.type-selector{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.cancel-button,.save-button{width:100%;justify-content:center}}@media (max-width: 480px){.form-section{padding:var(--spacing-md)}.icon-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr))}.icon-option{width:50px;height:50px}}.item-popup-backdrop{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn .3s ease-out}.item-popup-modal{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);max-width:600px;width:100%;max-height:80vh;overflow-y:auto;position:relative;animation:slideUp .4s ease-out;box-shadow:0 20px 60px #00000080,var(--glow-primary)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.popup-close-button{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);z-index:10}.popup-close-button:hover{background:#ff4a6e33;border-color:var(--color-error);color:var(--color-error);transform:rotate(90deg)}.popup-header{display:flex;align-items:flex-start;gap:var(--spacing-lg);padding:var(--spacing-xl);padding-right:calc(var(--spacing-xl) + 50px);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.popup-icon{flex-shrink:0;background:var(--color-bg-secondary);padding:var(--spacing-md);border-radius:var(--radius-md);border:2px solid var(--color-border);box-shadow:var(--glow-secondary)}.popup-title-section{flex:1;min-width:0}.popup-item-name{margin:0 0 var(--spacing-xs);color:var(--color-heading);font-size:var(--font-size-xl);text-shadow:var(--glow-primary);word-break:break-word}.popup-item-title{margin:0 0 var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:1.4}.popup-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.popup-badge.achievement{background:#ffd70033;color:var(--color-secondary);border:1px solid var(--color-secondary)}.popup-badge.inventory{background:#9b59b633;color:#9b59b6;border:1px solid #9b59b6}.popup-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:#ffffff05;border-bottom:1px solid var(--color-border)}.popup-content{padding:var(--spacing-xl)}.popup-content-body{color:var(--color-text-primary);line-height:1.7;font-size:var(--font-size-base)}.popup-content-body p{margin:0 0 var(--spacing-md)}.popup-content-body p:last-child{margin-bottom:0}.popup-content-body h1{font-size:var(--font-size-xl);color:var(--color-heading);margin:var(--spacing-lg) 0 var(--spacing-md)}.popup-content-body h2{font-size:var(--font-size-lg);color:var(--color-heading);margin:var(--spacing-md) 0 var(--spacing-sm)}.popup-content-body h3{font-size:var(--font-size-base);color:var(--color-heading);margin:var(--spacing-md) 0 var(--spacing-sm)}.popup-content-body strong{color:var(--color-text-primary);font-weight:var(--font-weight-bold)}.popup-content-body em{font-style:italic;color:var(--color-text-secondary)}.popup-content-body code{background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-xs);font-family:Fira Code,Source Code Pro,monospace;font-size:.9em;color:var(--color-secondary)}.popup-content-body pre{background:var(--color-bg-tertiary);padding:var(--spacing-md);border-radius:var(--radius-sm);overflow-x:auto;margin:var(--spacing-md) 0}.popup-content-body pre code{background:transparent;padding:0;color:var(--color-text-primary)}.popup-content-body a{color:var(--color-secondary);text-decoration:underline;transition:color var(--transition-fast)}.popup-content-body a:hover{color:var(--color-primary)}.popup-content-body li{margin-left:var(--spacing-lg);margin-bottom:var(--spacing-xs)}.popup-no-content{color:var(--color-text-muted);font-style:italic;text-align:center}@media (max-width: 768px){.item-popup-backdrop{padding:var(--spacing-md)}.item-popup-modal{max-height:90vh}.popup-header{flex-direction:column;align-items:center;text-align:center;padding-right:var(--spacing-xl)}.popup-title-section{width:100%}.popup-badge{justify-content:center}}@media (max-width: 480px){.popup-icon{padding:var(--spacing-sm)}.popup-icon .icon{width:48px;height:48px}.popup-content{padding:var(--spacing-md)}}.inventory-display-container{width:100%}.inventory-display-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.header-title{display:flex;align-items:center;gap:var(--spacing-md)}.header-title h2{margin:0;color:var(--color-heading);text-shadow:var(--glow-primary)}.show-all-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.show-all-link:hover{color:var(--color-primary);transform:translate(3px)}.inventory-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(2,1fr);gap:var(--spacing-md);grid-auto-flow:row;width:100%}.inventory-item-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-base);min-height:0;aspect-ratio:1 / 1;position:relative;overflow:hidden;min-width:0;max-width:100%}.inventory-item-box.filled{cursor:pointer}.inventory-item-box.empty{background:var(--color-bg-tertiary);border-style:dashed;opacity:.4;cursor:default}.inventory-item-box:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-secondary),var(--color-primary));transform:scaleX(0);transition:transform var(--transition-base)}.inventory-item-box.filled:hover{transform:translateY(-5px);border-color:var(--color-secondary);box-shadow:var(--glow-secondary)}.inventory-item-box.filled:hover:before{transform:scaleX(1)}.inventory-item-box.filled:active{transform:translateY(-2px)}.item-box-icon{display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast);flex-shrink:0}.item-box-icon svg{width:clamp(32px,4vw,56px);height:clamp(32px,4vw,56px)}.item-box-icon.empty-icon{opacity:.3}.inventory-item-box.filled:hover .item-box-icon{transform:scale(1.1)}.item-box-name{font-size:clamp(.625rem,1.2vw,.875rem);color:var(--color-text-primary);text-align:center;font-weight:var(--font-weight-medium);line-height:1.3;word-break:break-word;max-width:100%;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.item-box-name.empty-label{color:var(--color-text-muted);font-style:italic}.inventory-more-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:#ffd7001a;border:2px dashed var(--color-secondary);border-radius:var(--radius-md);min-height:120px;text-decoration:none;transition:all var(--transition-base)}.inventory-more-box:hover{background:#ffd70033;transform:translateY(-3px);border-style:solid}.more-count{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-secondary)}.more-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase}.inventory-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl);color:var(--color-text-secondary)}.loading-spinner{width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin 1s linear infinite}.inventory-empty{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center}.inventory-empty p{margin:0;color:var(--color-text-muted);font-style:italic}.inventory-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:#ff4a6e1a;border:2px solid var(--color-error);border-radius:var(--radius-md);text-align:center}.inventory-error p{margin:0;color:var(--color-error)}@media (max-width: 768px){.inventory-grid{gap:var(--spacing-sm)}.inventory-item-box{padding:var(--spacing-md)}}@media (max-width: 480px){.inventory-display-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.show-all-link{align-self:flex-end}.inventory-grid{gap:var(--spacing-xs)}.inventory-item-box{padding:var(--spacing-sm)}}@media (max-width: 360px){.inventory-grid{gap:4px}.inventory-item-box{padding:var(--spacing-xs);border-width:1px}}.achievements-display-container{width:100%}.achievements-display-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.achievements-display-header .header-title{display:flex;align-items:center;gap:var(--spacing-md)}.achievements-display-header .header-title h2{margin:0;color:var(--color-heading);text-shadow:var(--glow-primary)}.achievements-display-header .show-all-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.achievements-display-header .show-all-link:hover{color:var(--color-primary);transform:translate(3px)}.achievements-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.achievement-badge{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:linear-gradient(135deg,#ffd7000d,#9b59b60d);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden;text-align:center;width:100%}.achievement-badge:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--color-secondary),#9b59b6);transform:scaleY(0);transition:transform var(--transition-base);transform-origin:bottom}.achievement-badge:hover{border-color:var(--color-secondary);background:linear-gradient(135deg,#ffd7001a,#9b59b61a);transform:translateY(-5px);box-shadow:var(--glow-secondary)}.achievement-badge:hover:before{transform:scaleY(1)}.achievement-badge:active{transform:translateY(-2px)}.badge-glow{position:absolute;top:-50%;right:-20%;width:100px;height:200%;background:linear-gradient(90deg,transparent,rgba(255,215,0,.1),transparent);transform:rotate(15deg) translate(-100%);transition:transform .6s ease;pointer-events:none}.achievement-badge:hover .badge-glow{transform:rotate(15deg) translate(300%)}.badge-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:#ffd70026;border:2px solid var(--color-secondary);border-radius:var(--radius-full);box-shadow:0 0 20px #ffd7004d;transition:transform var(--transition-fast)}.achievement-badge:hover .badge-icon{transform:scale(1.1)}.badge-info{flex:1;min-width:0}.badge-name{margin:0 0 var(--spacing-xs);color:var(--color-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);text-shadow:0 0 10px rgba(255,215,0,.3)}.badge-title{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.badge-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.more-tags{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:2px 6px;background:#ffffff0d;border-radius:var(--radius-xs)}.achievements-more-badge{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:#ffd7000d;border:2px dashed var(--color-secondary);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-base)}.achievements-more-badge:hover{background:#ffd7001a;transform:translate(5px);border-style:solid}.more-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:#ffd7001a;border:2px dashed var(--color-secondary);border-radius:var(--radius-full)}.more-info{display:flex;flex-direction:column}.more-info .more-count{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-secondary)}.more-info .more-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.achievements-loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-xl);color:var(--color-text-secondary)}.achievements-loading .loading-spinner{width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin 1s linear infinite}.achievements-empty{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center}.achievements-empty p{margin:0;color:var(--color-text-muted);font-style:italic}.achievements-error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);background:#ff4a6e1a;border:2px solid var(--color-error);border-radius:var(--radius-md);text-align:center}.achievements-error p{margin:0;color:var(--color-error)}@media (max-width: 768px){.achievement-badge{padding:var(--spacing-sm) var(--spacing-md)}.badge-icon{width:48px;height:48px}.badge-icon .icon{width:24px;height:24px}}@media (max-width: 480px){.achievements-display-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.achievements-display-header .show-all-link{align-self:flex-end}.badge-title{-webkit-line-clamp:1}.badge-tags{display:none}}.home-page{width:100%;animation:fadeIn .6s ease-out}.hero-section.character-hero{display:flex;align-items:flex-start;gap:var(--spacing-3xl);padding:var(--spacing-3xl) var(--spacing-xl);margin:var(--spacing-xl) auto;max-width:1400px;position:relative}.info-section{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);max-width:1400px;margin:0 auto var(--spacing-xl);padding:0 var(--spacing-xl)}.info-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast)}.info-card:hover{border-color:var(--color-secondary);box-shadow:var(--shadow-md)}.info-card svg{color:var(--color-secondary)}.section{max-width:1400px;margin:0 auto;padding:var(--spacing-3xl) var(--spacing-xl)}.section-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);position:relative}.section-header h2{margin:0;color:var(--color-heading);text-shadow:var(--glow-primary);flex:1}.show-all-link-header{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);transition:all var(--transition-fast);margin-left:auto}.show-all-link-header:hover{color:var(--color-primary);transform:translate(3px)}.section-footer{text-align:center;margin-top:var(--spacing-xl)}.view-all-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.view-all-link:hover{gap:var(--spacing-sm);text-shadow:var(--glow-secondary)}.attributes-section{overflow:visible}.stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:var(--spacing-sm);width:100%;grid-auto-flow:column}.stat-block{position:relative;background:transparent;border:none;border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center;transition:all var(--transition-base);cursor:pointer;min-width:0;max-width:100%;aspect-ratio:1 / 1;display:flex;flex-direction:column;justify-content:center;align-items:center}.stat-block:hover,.stat-block.hovered{background:#ffd7000d;border-radius:var(--radius-md);transform:translateY(-3px);z-index:10;overflow:visible}.stat-name{font-size:clamp(.625rem,1.5vw,1rem);color:var(--color-secondary);font-weight:var(--font-weight-bold);letter-spacing:.05em;margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:clip}.stat-score{font-size:clamp(1.5rem,3vw,2.5rem);color:var(--color-heading);font-weight:var(--font-weight-bold);line-height:1;margin-bottom:2px}.stat-modifier{font-size:clamp(.75rem,1.8vw,1.25rem);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.stat-description{font-size:clamp(.5rem,1vw,.75rem);color:var(--color-text-muted);margin-top:var(--spacing-xs);display:block;line-height:1.2;overflow:hidden;text-overflow:clip;white-space:nowrap}@media (max-width: 900px){.stat-description{display:none}}.stat-tooltip{position:absolute;bottom:calc(100% + var(--spacing-xs));left:50%;transform:translate(-50%);background:var(--color-bg-secondary);border:2px solid var(--color-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);min-width:250px;max-width:300px;z-index:1000;box-shadow:0 10px 30px #000000b3;animation:fadeIn .2s ease-out;pointer-events:none}.stat-description-full{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)!important}.skills-section{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl)}.skills-title{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-lg);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-xs)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-lg)}.project-card{display:flex;flex-direction:column;padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-base);min-height:300px;position:relative}.project-card:hover{border-color:var(--color-secondary);transform:translateY(-5px);box-shadow:var(--glow-secondary)}.project-icon{margin-bottom:var(--spacing-md);color:var(--color-secondary)}.project-card h3{margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-lg)}.project-hover-description{flex:1;margin-bottom:var(--spacing-md)}.project-hover-description p{color:var(--color-text-secondary);line-height:1.6;margin:0}.project-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.project-stats{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.project-date{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted);font-size:var(--font-size-xs)}.project-link-indicator{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.quest-stat{text-align:center;padding:var(--spacing-md);background:transparent;border-radius:var(--radius-md)}.quest-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.main-quests-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.quest-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--spacing-xs) 0;line-height:1.5}.quest-progress-public{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.progress-bar-small{flex:1;height:6px;background:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden}.progress-fill-small{height:100%;background:linear-gradient(90deg,var(--color-secondary-dark),var(--color-secondary));border-radius:var(--radius-full);transition:width .5s ease}.quest-progress-public span{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.side-quests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.quest-card{display:flex;flex-direction:column;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-base)}.quest-card.main{border:2px solid var(--color-secondary)}.quest-card.side{border:2px solid var(--color-primary)}.quest-card p{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.4;flex:1}.empty-section{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-3xl);background:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);text-align:center}.loading-placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);color:var(--color-text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin 1s linear infinite}.cta-section{background:linear-gradient(135deg,#bb86fc1a,#ffd7001a);padding:var(--spacing-3xl) var(--spacing-xl);margin-top:var(--spacing-3xl)}.cta-content{max-width:600px;margin:0 auto;text-align:center}.cta-content h2{color:var(--color-heading);margin:var(--spacing-md) 0}.cta-content p{color:var(--color-text-secondary);line-height:1.7;margin-bottom:var(--spacing-lg)}.cta-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,var(--color-primary-dark),var(--color-primary));color:#fff;border:none;cursor:pointer;border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold);transition:all var(--transition-base);box-shadow:var(--glow-primary)}.cta-button:hover{transform:translateY(-3px);box-shadow:var(--glow-primary-strong)}@media (max-width: 1024px){.hero-section.character-hero{padding:var(--spacing-xl);gap:var(--spacing-xl)}.skills-section,.projects-grid,.info-section{grid-template-columns:1fr}}@media (max-width: 768px){.section{padding:var(--spacing-xl) var(--spacing-md)}.hero-section.character-hero{flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-xl) var(--spacing-md)}.character-portrait img,.portrait-placeholder{width:150px;height:150px}.character-name{font-size:var(--font-size-2xl)}.character-actions{justify-content:center}.info-section{grid-template-columns:1fr;padding:0 var(--spacing-md)}.stats-grid{gap:var(--spacing-xs)}.stat-block{padding:var(--spacing-sm)}.stat-tooltip{position:fixed;bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:300px}.projects-grid,.side-quests-grid,.main-quests-grid{grid-template-columns:1fr}.quest-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.character-actions{flex-direction:column;width:100%}.action-button{width:100%}.section-header{flex-wrap:wrap}.show-all-link-header{width:100%;justify-content:flex-end;margin-top:var(--spacing-sm)}.stats-grid{gap:4px}.stat-block{padding:var(--spacing-xs)}}@media (max-width: 360px){.stats-grid{gap:2px}.stat-block{padding:4px;border-width:1px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.blog-page{max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .4s ease-out}.blog-header{margin-bottom:var(--spacing-xl)}.blog-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.blog-title-section h1{margin:0;color:var(--color-heading);text-shadow:var(--glow-primary)}.blog-title-section p{margin:var(--spacing-xs) 0 0;color:var(--color-text-secondary)}.blog-filters{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-xl)}.type-filters{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);flex-wrap:wrap}.filter-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{background:#ffffff0d;color:var(--color-text-primary)}.filter-btn.active{background:var(--color-secondary);border-color:var(--color-secondary);color:var(--color-primary-dark);font-weight:var(--font-weight-semibold)}.tag-filters{display:flex;flex-direction:column;gap:var(--spacing-sm)}.filter-label{color:var(--color-text-muted);font-size:var(--font-size-sm)}.tag-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.tag-filter-btn{padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff0d;border:2px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.tag-filter-btn:hover,.tag-filter-btn.active{background:#ffffff1a;color:var(--tag-color)}.clear-filter-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:none;color:var(--color-error);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.clear-filter-btn:hover{text-decoration:underline}.posts-count{text-align:right;color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--spacing-sm)}.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg)}.post-card-large{display:flex;flex-direction:column;padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-base)}.post-card-large:hover{border-color:var(--color-primary);transform:translateY(-5px);box-shadow:var(--glow-primary)}.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.post-type-badge{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.post-date{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted);font-size:var(--font-size-xs)}.post-card-large h3{margin:0 0 var(--spacing-sm);color:var(--color-heading);font-size:var(--font-size-lg);line-height:1.3}.post-card-large p{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--spacing-md);flex:1}.post-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.read-more{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-primary);font-weight:var(--font-weight-medium);margin-top:auto}.post-card-large:hover .read-more{gap:var(--spacing-sm)}@media (max-width: 768px){.blog-page{padding:var(--spacing-md)}.blog-title-section{flex-direction:column;text-align:center}.type-filters{justify-content:center}.posts-grid{grid-template-columns:1fr}.post-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.projects-page{max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .4s ease-out}.projects-header{margin-bottom:var(--spacing-xl)}.projects-title-section{display:flex;align-items:center;gap:var(--spacing-md)}.projects-title-section h1{margin:0;color:var(--color-heading);text-shadow:var(--glow-primary)}.projects-title-section p{margin:var(--spacing-xs) 0 0;color:var(--color-text-secondary)}.projects-grid-public{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--spacing-xl)}.project-card-public{display:flex;flex-direction:column;padding:var(--spacing-lg);background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;transition:all var(--transition-base);position:relative;overflow:hidden}.project-card-public:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-secondary),var(--color-primary));opacity:0;transition:opacity var(--transition-fast)}.project-card-public:hover{border-color:var(--color-secondary);transform:translateY(-8px);box-shadow:var(--glow-secondary)}.project-card-public:hover:before{opacity:1}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.project-icon-large{color:var(--color-secondary);opacity:.8}.project-status-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.project-card-public h3{margin:0 0 var(--spacing-sm);color:var(--color-heading);font-size:var(--font-size-xl);line-height:1.3}.project-card-public p{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--spacing-md);flex:1}.project-tags-public{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.project-meta-public{margin-bottom:var(--spacing-md)}.project-date-range{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted);font-size:var(--font-size-sm)}.view-project{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);font-weight:var(--font-weight-semibold);margin-top:auto}.project-card-public:hover .view-project{gap:var(--spacing-sm)}@media (max-width: 768px){.projects-page{padding:var(--spacing-md)}.projects-title-section{flex-direction:column;text-align:center}.projects-grid-public{grid-template-columns:1fr}}.page-detail{max-width:900px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .4s ease-out}.page-detail-nav{margin-bottom:var(--spacing-lg)}.back-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-fast)}.back-link:hover{color:var(--color-secondary);gap:var(--spacing-sm)}.back-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-secondary);color:var(--color-primary-dark);border:none;border-radius:var(--radius-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.back-button:hover{transform:translateY(-2px);box-shadow:var(--glow-secondary)}.page-article{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.article-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border);background:#ffffff05}.article-type{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;margin-bottom:var(--spacing-md)}.article-header h1{margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-2xl);line-height:1.3;text-shadow:var(--glow-primary)}.article-meta{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.article-date{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-muted);font-size:var(--font-size-sm)}.article-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.project-info-box{margin:var(--spacing-lg);padding:var(--spacing-lg);background:#d4af371a;border:2px solid var(--color-border);border-radius:var(--radius-md)}.project-info-box h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-secondary)}.project-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.detail-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.detail-label{color:var(--color-text-muted);font-size:var(--font-size-xs);text-transform:uppercase;font-weight:var(--font-weight-medium)}.detail-value{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.article-content{padding:var(--spacing-xl);color:var(--color-text-primary);line-height:1.8;font-size:var(--font-size-base)}.article-content p{margin:0 0 var(--spacing-md)}.article-content h1{font-size:var(--font-size-2xl);color:var(--color-heading);margin:var(--spacing-xl) 0 var(--spacing-md)}.article-content h2{font-size:var(--font-size-xl);color:var(--color-heading);margin:var(--spacing-lg) 0 var(--spacing-md)}.article-content h3{font-size:var(--font-size-lg);color:var(--color-heading);margin:var(--spacing-md) 0 var(--spacing-sm)}.article-content strong{color:var(--color-text-primary);font-weight:var(--font-weight-bold)}.article-content em{font-style:italic}.article-content code{background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-xs);font-family:Fira Code,monospace;font-size:.9em;color:var(--color-primary)}.article-content pre{background:var(--color-bg-tertiary);padding:var(--spacing-md);border-radius:var(--radius-sm);overflow-x:auto;margin:var(--spacing-md) 0}.article-content pre code{background:transparent;padding:0;color:var(--color-text-primary)}.article-content ul{margin:var(--spacing-md) 0;padding-left:var(--spacing-lg)}.article-content li{margin-bottom:var(--spacing-xs)}.no-content{color:var(--color-text-muted);font-style:italic;text-align:center}.linked-quests-box{margin:var(--spacing-lg);padding:var(--spacing-lg);background:#bb86fc1a;border:1px solid rgba(187,134,252,.3);border-radius:var(--radius-md)}.linked-quests-box h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-primary)}.quests-links{display:flex;flex-direction:column;gap:var(--spacing-xs)}.quest-link{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:#ffffff0d;border-radius:var(--radius-sm);text-decoration:none;color:var(--color-text-primary);transition:all var(--transition-fast)}.quest-link:hover{background:#ffffff1a;transform:translate(5px)}.devlogs-box{margin:var(--spacing-lg);padding:var(--spacing-lg);background:#9b59b61a;border:2px solid var(--color-border);border-radius:var(--radius-md)}.devlogs-box h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:#9b59b6}.devlog-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#ffffff08;border:1px solid var(--color-border);border-radius:var(--radius-sm);text-decoration:none;color:var(--color-text-primary);transition:all var(--transition-fast)}.devlog-link:hover{background:#ffffff14;border-color:var(--color-primary);transform:translate(5px)}.devlog-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#9b59b633;border-radius:var(--radius-sm);flex-shrink:0;color:#9b59b6}.devlog-info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.devlog-info h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.devlog-date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.issues-box{margin:var(--spacing-lg);padding:var(--spacing-lg);background:#e74c3c0d;border:2px solid var(--color-border);border-radius:var(--radius-md)}.issues-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.issues-header h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0;color:var(--color-error)}.toggle-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-fast)}.toggle-button:hover{border-color:var(--color-secondary);color:var(--color-secondary);background:#ffffff0d}.issues-section{margin-bottom:var(--spacing-lg)}.issues-section:last-child{margin-bottom:0}.issues-section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin:0 0 var(--spacing-md);text-transform:uppercase;letter-spacing:.05em}.issues-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.issue-item{padding:var(--spacing-md);background:#ffffff08;border:1px solid var(--color-border);border-left:3px solid var(--color-border);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.issue-item.bug{border-left-color:var(--color-error)}.issue-item.improvement{border-left-color:var(--color-info)}.issue-item:hover{background:#ffffff0f}.issue-header-row{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.issue-title{flex:1;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.issue-status{padding:2px var(--spacing-xs);border-radius:var(--radius-xs);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em}.issue-status.status-open{background:#3498db33;color:#3498db}.issue-status.status-in_progress{background:#f1c40f33;color:#f1c40f}.issue-status.status-resolved{background:#2ecc7133;color:#2ecc71}.issue-status.status-closed{background:#95a5a633;color:#95a5a6}.issue-description{margin:var(--spacing-xs) 0 0 0;font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.severity-badge{display:inline-block;padding:2px var(--spacing-xs);border-radius:var(--radius-xs);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em;margin-top:var(--spacing-xs)}.severity-badge.severity-critical{background:#e74c3c4d;color:#e74c3c}.severity-badge.severity-major{background:#e67e224d;color:#e67e22}.severity-badge.severity-minor{background:#f1c40f4d;color:#f1c40f}@media (max-width: 768px){.page-detail,.article-header{padding:var(--spacing-md)}.article-header h1{font-size:var(--font-size-xl)}.article-content{padding:var(--spacing-md)}.project-info-box,.linked-quests-box,.devlogs-box,.issues-box{margin:var(--spacing-md);padding:var(--spacing-md)}.issues-header{flex-direction:column;align-items:flex-start}.toggle-button{width:100%}}.public-quests-page{max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .4s ease-out}.quests-header-public{margin-bottom:var(--spacing-xl)}.quests-title-public{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.quests-title-public h1{margin:0;color:var(--color-heading);text-shadow:var(--glow-primary)}.quests-title-public p{margin:var(--spacing-xs) 0 0;color:var(--color-text-secondary)}.quest-stats-public{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.stat-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.stat-card svg{color:var(--color-secondary)}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-heading)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.quest-type-filter{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-xl);flex-wrap:wrap}.type-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.type-btn:hover{background:#ffffff0d;color:var(--color-text-primary)}.type-btn.active{background:var(--color-secondary);border-color:var(--color-secondary);color:var(--color-primary-dark);font-weight:var(--font-weight-semibold)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;background:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-lg)}.empty-state h2{color:var(--color-heading);margin:var(--spacing-md) 0}.empty-state p{color:var(--color-text-secondary)}.quests-grid-public{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-lg)}.quest-card-public-full{display:flex;flex-direction:column;padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);cursor:pointer}.quest-card-public-full:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.quest-card-public-full:focus{outline:2px solid var(--color-secondary);outline-offset:2px}.quest-card-header-public{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.quest-type-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md);color:var(--color-primary-dark)}.quest-status-public{padding:var(--spacing-xs) var(--spacing-sm);border:2px solid;border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase}.quest-card-public-full h3{margin:0 0 var(--spacing-sm);color:var(--color-heading);font-size:var(--font-size-lg)}.quest-description-public{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--spacing-md);flex:1}.quest-progress-public-full{margin-bottom:var(--spacing-md)}.progress-label{display:flex;justify-content:space-between;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.progress-bar-public{width:100%;height:10px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-xs)}.progress-fill-public{height:100%;background:linear-gradient(90deg,var(--color-secondary-dark),var(--color-secondary));border-radius:var(--radius-full);transition:width .5s ease}.progress-detail{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:center}.quest-tags-public-full{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:auto}@media (max-width: 768px){.public-quests-page{padding:var(--spacing-md)}.quests-title-public{flex-direction:column;text-align:center}.quest-type-filter{justify-content:center}.quests-grid-public{grid-template-columns:1fr}}.public-quest-view-container{width:100%;max-width:1000px;margin:0 auto;padding:var(--spacing-lg);animation:fadeIn .4s ease-out}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);color:var(--color-text-secondary)}.loading-spinner-large{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}@keyframes spin{to{transform:rotate(360deg)}}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center;background:var(--color-bg-card);border:2px dashed var(--color-border);border-radius:var(--radius-lg)}.error-state h2{color:var(--color-error);margin:var(--spacing-md) 0}.error-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.public-quest-view-header{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.back-button-small{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.back-button-small:hover{background:#ffffff0d;color:var(--color-text-primary);border-color:var(--color-border-light)}.quest-type-badge-large{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);color:var(--color-primary-dark);font-weight:var(--font-weight-semibold);text-transform:uppercase;font-size:var(--font-size-sm)}.quest-title{flex:1;margin:0;color:var(--color-heading);text-shadow:var(--glow-primary);font-size:var(--font-size-2xl)}.back-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-secondary-dark),var(--color-secondary));color:var(--color-primary-dark);border:2px solid var(--color-secondary-light);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--glow-secondary)}.back-button:hover{transform:translateY(-2px);box-shadow:var(--glow-primary-strong)}.quest-status-section{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.status-badge-large{padding:var(--spacing-sm) var(--spacing-lg);border:3px solid;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);text-transform:uppercase}.quest-meta-info{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.quest-progress-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.quest-progress-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.progress-container{display:flex;flex-direction:column;gap:var(--spacing-sm)}.progress-bar-large{width:100%;height:16px;background:var(--color-bg-tertiary);border-radius:var(--radius-md);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-secondary-dark),var(--color-secondary));border-radius:var(--radius-md);transition:width .5s ease}.progress-stats{display:flex;justify-content:space-between;align-items:center}.progress-percentage{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-secondary)}.progress-count{font-size:var(--font-size-sm);color:var(--color-text-muted)}.quest-description-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.quest-description-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.description-content{color:var(--color-text-primary);line-height:1.7;white-space:pre-wrap}.quest-tags-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.quest-tags-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.tags-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.quest-subquests-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.quest-subquests-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.subquests-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.subquest-item-readonly{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-sm)}.checkbox-display{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-xs);flex-shrink:0;font-size:16px;font-weight:700;color:var(--color-primary-dark)}.checkbox-display.completed{background:var(--color-secondary);border-color:var(--color-secondary)}.subquest-title{flex:1;color:var(--color-text-primary);font-size:var(--font-size-base)}.subquest-title.completed{text-decoration:line-through;color:var(--color-text-muted)}.no-subquests{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--color-text-muted);text-align:center}.quest-pages-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.quest-pages-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.pages-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.page-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.page-item:hover{background:#ffffff0d}.page-item:focus{outline:2px solid var(--color-secondary);outline-offset:2px}.page-item .page-title{flex:1;color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.quest-devlogs-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.quest-devlogs-section h3{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading)}.devlogs-loading{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--color-text-secondary)}.devlogs-loading .loading-spinner{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin 1s linear infinite}.devlogs-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.devlog-item{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.devlog-item:hover{background:#ffffff0d;border-color:var(--color-border-light);transform:translate(4px)}.devlog-item:focus{outline:2px solid var(--color-secondary);outline-offset:2px}.devlog-header{display:flex;align-items:center;gap:var(--spacing-sm)}.devlog-title{flex:1;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.devlog-date{color:var(--color-text-muted);font-size:var(--font-size-xs);white-space:nowrap}.devlog-work-summary{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);padding-left:32px}.devlog-work-summary span{flex:1}@media (max-width: 768px){.public-quest-view-container{padding:var(--spacing-md)}.public-quest-view-header{flex-direction:column;align-items:stretch}.quest-title{text-align:center;font-size:var(--font-size-xl)}.quest-type-badge-large{justify-content:center}.back-button-small{position:absolute;top:var(--spacing-md);left:var(--spacing-md)}.quest-status-section{flex-direction:column;text-align:center}.quest-meta-info{flex-direction:column;gap:var(--spacing-sm)}.meta-item{justify-content:center}}@media (max-width: 480px){.progress-stats{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.full-inventory-page{width:100%;max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .6s ease-out}.full-page-header{margin-bottom:var(--spacing-3xl);text-align:center}.back-to-home{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xl);transition:all var(--transition-fast)}.back-to-home:hover{color:var(--color-primary);transform:translate(-5px)}.full-page-title{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-3xl);text-shadow:var(--glow-primary)}.full-page-subtitle{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:1.6}.full-inventory-content{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}@media (max-width: 768px){.full-inventory-page{padding:var(--spacing-md)}.full-page-title{font-size:var(--font-size-2xl);flex-direction:column}.full-page-title .icon{width:36px;height:36px}.full-inventory-content{padding:var(--spacing-md)}}.full-achievements-page{width:100%;max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .6s ease-out}.full-achievements-page .full-page-header{margin-bottom:var(--spacing-3xl);text-align:center}.full-achievements-page .back-to-home{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xl);transition:all var(--transition-fast)}.full-achievements-page .back-to-home:hover{color:var(--color-primary);transform:translate(-5px)}.full-achievements-page .full-page-title{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-3xl);text-shadow:var(--glow-primary)}.full-achievements-page .full-page-subtitle{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:1.6}.full-achievements-content{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}@media (max-width: 768px){.full-achievements-page{padding:var(--spacing-md)}.full-achievements-page .full-page-title{font-size:var(--font-size-2xl);flex-direction:column}.full-achievements-page .full-page-title .icon{width:36px;height:36px}.full-achievements-content{padding:var(--spacing-md)}}.character-stats-page{width:100%;max-width:1400px;margin:0 auto;padding:var(--spacing-xl);animation:fadeIn .6s ease-out}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-md);color:var(--color-text-secondary)}.character-stats-page .hero-section{display:flex;align-items:flex-start;gap:var(--spacing-3xl);padding:var(--spacing-3xl);background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);position:relative;overflow:hidden}.character-stats-page .hero-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-secondary),var(--color-primary))}.character-portrait{position:relative;flex-shrink:0}.character-portrait img{width:200px;height:200px;border-radius:var(--radius-lg);object-fit:cover;border:3px solid var(--color-secondary);box-shadow:var(--glow-secondary)}.portrait-placeholder{width:200px;height:200px;background:var(--color-bg-tertiary);border-radius:var(--radius-lg);border:3px solid var(--color-border);display:flex;align-items:center;justify-content:center}.level-badge{position:absolute;bottom:-10px;right:-10px;background:linear-gradient(135deg,var(--color-secondary-dark),var(--color-secondary));padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;box-shadow:0 4px 12px #ffd7004d}.level-label{font-size:var(--font-size-xs);color:var(--color-primary-dark);font-weight:var(--font-weight-bold)}.level-number{font-size:var(--font-size-2xl);color:var(--color-primary-dark);font-weight:var(--font-weight-bold);line-height:1}.character-info{flex:1}.character-name{margin:0 0 var(--spacing-xs);font-size:var(--font-size-3xl);color:var(--color-heading);text-shadow:var(--glow-primary)}.character-title{margin:0 0 var(--spacing-lg);font-size:var(--font-size-lg);color:var(--color-secondary);font-weight:var(--font-weight-medium)}.xp-bar{margin-bottom:var(--spacing-lg)}.xp-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.xp-track{height:20px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;border:1px solid var(--color-border)}.xp-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);transition:width 1s ease-out;box-shadow:0 0 10px #9b59b680}.xp-percentage{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs);text-align:right}.character-description{margin:0 0 var(--spacing-lg);color:var(--color-text-secondary);line-height:1.6}.character-actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.action-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);border:2px solid;white-space:nowrap;min-width:150px}.action-button.linkedin{background:#0077b54d;border-color:#0077b5;color:#fff}.action-button.linkedin:hover{background:#0077b580;transform:translateY(-2px);box-shadow:0 4px 12px #0077b54d}.action-button.contact{background:#9b59b64d;border-color:var(--color-primary);color:#fff}.action-button.contact:hover{background:#9b59b680;transform:translateY(-2px);box-shadow:0 4px 12px #9b59b64d}.info-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.info-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.info-card>div{display:flex;flex-direction:column}.info-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.attributes-section{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.section-title{display:flex;align-items:center;gap:var(--spacing-md);margin:0 0 var(--spacing-xl);color:var(--color-heading);font-size:var(--font-size-xl);text-shadow:var(--glow-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-lg)}.stat-block{position:relative;background:var(--color-bg-tertiary);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center;transition:all var(--transition-base);cursor:help}.stat-block:hover{border-color:var(--color-secondary);transform:translateY(-3px);box-shadow:var(--glow-secondary)}.stat-name{font-size:var(--font-size-sm);color:var(--color-secondary);font-weight:var(--font-weight-bold);letter-spacing:.1em;margin-bottom:var(--spacing-xs)}.stat-score{font-size:var(--font-size-3xl);color:var(--color-heading);font-weight:var(--font-weight-bold);line-height:1;margin-bottom:var(--spacing-xs)}.stat-modifier{font-size:var(--font-size-lg);color:var(--color-primary);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-sm)}.stat-description{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.stat-raw{font-size:var(--font-size-xs);color:var(--color-text-muted)}.stat-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--color-bg-secondary);border:2px solid var(--color-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);min-width:250px;z-index:100;box-shadow:0 10px 30px #00000080;animation:fadeIn .2s ease-out}.stat-tooltip strong{display:block;color:var(--color-secondary);margin-bottom:var(--spacing-xs)}.stat-tooltip p{margin:0 0 var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4}.stat-details{color:var(--color-text-muted);font-style:italic}.inverse-note{color:var(--color-success);font-weight:var(--font-weight-semibold)}.stats-error{text-align:center;color:var(--color-error);padding:var(--spacing-xl)}.skills-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.skills-column{min-width:0}.skills-title{margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-lg);border-bottom:2px solid var(--color-border);padding-bottom:var(--spacing-xs)}.skills-list{list-style:none;padding:0;margin:0}.skill-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.skill-item:last-child{border-bottom:none}.skill-name{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.skill-level{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-bg-tertiary);padding:2px 8px;border-radius:var(--radius-xs)}.quests-section{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.quest-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.quest-stat{text-align:center;padding:var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.quest-stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-secondary)}.quest-stat-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase}.show-all-button{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--color-secondary);text-decoration:none;font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xl);transition:all var(--transition-fast)}.show-all-button:hover{color:var(--color-primary);transform:translate(5px)}.quest-category{margin-bottom:var(--spacing-xl)}.quest-category:last-child{margin-bottom:0}.quest-category-title{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 0 var(--spacing-md);color:var(--color-heading);font-size:var(--font-size-base)}.quest-cards{display:grid;gap:var(--spacing-md)}.quest-cards.main-quests{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.quest-cards.side-quests{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.quest-card{display:block;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);text-decoration:none;transition:all var(--transition-base)}.quest-card:hover{border-color:var(--color-secondary);transform:translateY(-3px);box-shadow:var(--glow-secondary)}.quest-card.main{border-left:4px solid var(--color-secondary)}.quest-card.side{border-left:4px solid var(--color-primary)}.quest-card h4{margin:0 0 var(--spacing-xs);color:var(--color-heading);font-size:var(--font-size-base)}.quest-card p{margin:0 0 var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.4}.quest-status{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase}.inventory-achievements-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.contact-popup-backdrop{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.contact-popup{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-3xl);text-align:center;position:relative;max-width:400px}.popup-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast)}.popup-close:hover{color:var(--color-error)}.contact-popup h3{margin:var(--spacing-lg) 0 var(--spacing-md);color:var(--color-heading)}.contact-popup p{margin:0;color:var(--color-text-secondary)}@media (max-width: 768px){.character-stats-page{padding:var(--spacing-md)}.character-stats-page .hero-section{flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-xl);gap:var(--spacing-xl)}.character-portrait img,.portrait-placeholder{width:150px;height:150px}.character-name{font-size:var(--font-size-2xl)}.character-actions{justify-content:center}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-tooltip{position:fixed;bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:300px}.quest-cards.main-quests,.quest-cards.side-quests{grid-template-columns:1fr}}@media (max-width: 480px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat-block{padding:var(--spacing-md)}.stat-score{font-size:var(--font-size-2xl)}.skills-section{grid-template-columns:1fr}}.success-toast{position:fixed;top:var(--spacing-xl);right:var(--spacing-xl);z-index:var(--z-modal);display:flex;align-items:center;gap:var(--spacing-sm);background:var(--color-success);color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);animation:slideInToast .3s ease-out}.success-toast p{margin:0;font-weight:var(--font-weight-semibold)}@keyframes slideInToast{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}
