﻿@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&display=swap";:root{--color-primary: #3b82f6;--color-secondary: #10b981;--color-accent: #f59e0b;--color-primary-oklch: oklch(0.646 0.222 264.376);--color-secondary-oklch: oklch(0.696 0.17 162.48);--color-accent-oklch: oklch(0.769 0.188 70.08);--color-gold: #d4af37;--color-gold-dark: #d97706;--color-amber-light: #fbbf24;--color-purple: #8b5cf6;--color-pink: #ec4899;--color-gold-oklch: oklch(0.828 0.189 84.429);--color-gold-dark-oklch: oklch(0.627 0.265 40);--color-amber-light-oklch: oklch(0.845 0.165 78);--bg-fantasy-dark-primary: #2c1810;--bg-fantasy-dark-secondary: #1f120a;--bg-fantasy-dark-tertiary: #1a0f08;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--text-primary: #1f2937;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--text-inverse: #ffffff;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--space-xs: 0.25rem;--space-sm: 0.5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.1);--shadow-md: 0 4px 8px rgba(0, 0, 0, 0.15);--shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.2);--shadow-xl: 0 12px 24px rgba(0, 0, 0, 0.25);--shadow-legendary: 0 16px 32px rgba(0, 0, 0, 0.3);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, 0.1);--btn-height-sm: 32px;--btn-padding-sm: 0.25rem 0.75rem;--btn-font-sm: 0.8125rem;--btn-height-md: 40px;--btn-padding-md: 0.5rem 1rem;--btn-font-md: 0.875rem;--btn-height-lg: 48px;--btn-padding-lg: 0.75rem 1.5rem;--btn-font-lg: 1rem;--btn-min-width: 44px;--btn-min-height: 44px;--transition-instant: 0.1s;--transition-fast: 0.2s;--transition-base: 0.3s;--transition-slow: 0.5s;--transition-epic: 0.8s;--ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);--ease-out: cubic-bezier(0, 0, 0.2, 1);--ease-in: cubic-bezier(0.4, 0, 1, 1);--ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);--z-base: 1;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--z-toast: 10000;--font-family-base: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-family-fantasy: "Cinzel", Georgia, "Times New Roman", serif;--font-xs: 0.75rem;--font-sm: 0.875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--font-5xl: 3rem;--font-6xl: 4rem;--font-7xl: 5rem;--font-8xl: 6rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--card-padding: var(--space-lg);--card-border-width: 2px;--card-border-color: rgba(139, 92, 246, 0.2);--card-bg: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.95) 100%);--card-backdrop-filter: blur(10px);--input-height: var(--btn-height-md);--input-padding: var(--btn-padding-md);--input-border-width: 2px;--input-border-color: #e2e8f0;--input-border-color-focus: var(--color-primary);--input-bg: #ffffff;--modal-backdrop-bg: rgba(0, 0, 0, 0.5);--modal-backdrop-filter: blur(4px);--modal-max-width: 600px;--modal-padding: var(--space-xl);--gradient-primary: linear-gradient(135deg, #667eea 0%, #3b82f6 100%);--gradient-secondary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);--gradient-gold: linear-gradient(135deg, #d4af37 0%, #f59e0b 100%);--gradient-purple: linear-gradient(135deg, #d97706 0%, #ec4899 100%);--gradient-fantasy-dark: linear-gradient(to bottom, #2c1810 0%, #1f120a 50%, #1a0f08 100%);--gradient-amber-glow: linear-gradient(to right, #d97706 0%, #f59e0b 100%);--gradient-amber-button: linear-gradient(to right, #d97706 0%, #f59e0b 100%);--gradient-amber-button-hover: linear-gradient(to right, #b45309 0%, #d97706 100%);--gradient-card-header: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(245, 158, 11, 0.05) 100%);--gradient-card-bg: linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.95) 100%);--gradient-card-fantasy: linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0%, rgba(248, 250, 252, 0.02) 100%);--focus-ring-width: 3px;--focus-ring-color: #d97706;--focus-ring-offset: 2px;--focus-ring-shadow: 0 0 0 var(--focus-ring-width) rgba(217, 119, 6, 0.2);--touch-target-min: 44px;--contrast-text-primary: 7.1;--contrast-text-secondary: 4.6}[data-theme=dark]{--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--card-bg: linear-gradient(135deg, rgba(30, 41, 59, 0.95) 0%, rgba(15, 23, 42, 0.95) 100%);--card-border-color: rgba(71, 85, 105, 0.6);--input-bg: #1e293b;--input-border-color: #334155;--shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);--shadow-md: 0 4px 8px rgba(0, 0, 0, 0.4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.5);--shadow-xl: 0 12px 24px rgba(0, 0, 0, 0.6);--shadow-legendary: 0 16px 32px rgba(0, 0, 0, 0.7)}@media(prefers-color-scheme: dark){:root{--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--card-bg: linear-gradient(135deg, rgba(30, 41, 59, 0.95) 0%, rgba(15, 23, 42, 0.95) 100%);--card-border-color: rgba(71, 85, 105, 0.6);--input-bg: #1e293b;--input-border-color: #334155;--shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.3);--shadow-md: 0 4px 8px rgba(0, 0, 0, 0.4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.5);--shadow-xl: 0 12px 24px rgba(0, 0, 0, 0.6);--shadow-legendary: 0 16px 32px rgba(0, 0, 0, 0.7)}}@media(prefers-reduced-motion: reduce){:root{--transition-instant: 0.01ms;--transition-fast: 0.01ms;--transition-base: 0.01ms;--transition-slow: 0.01ms;--transition-epic: 0.01ms}}:root{--primary: var(--color-primary);--secondary: var(--color-secondary);--accent: var(--color-accent);--gradient-primary: var(--gradient-primary);--gradient-secondary: var(--gradient-secondary);--shadow-sm: var(--shadow-sm);--shadow-md: var(--shadow-md);--shadow-lg: var(--shadow-lg);--shadow-xl: var(--shadow-xl);--transition-fast: var(--transition-fast);--transition-base: var(--transition-base);--transition-slow: var(--transition-slow);--radius-sm: var(--radius-sm);--radius-md: var(--radius-md);--radius-lg: var(--radius-lg);--radius-xl: var(--radius-xl);--radius-full: var(--radius-full)}.text-fantasy,.font-fantasy{font-family:var(--font-family-fantasy)}.heading-fantasy{font-family:var(--font-family-fantasy);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight)}.heading-fantasy-xl{font-family:var(--font-family-fantasy);font-size:var(--font-6xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.text-glow-amber{text-shadow:0 0 30px rgba(217,119,6,.5)}.text-glow-amber-strong{text-shadow:0 0 40px rgba(217,119,6,.7)}.text-glow-gold{text-shadow:0 0 20px rgba(251,191,36,.6)}.bg-fantasy-dark{background:var(--gradient-fantasy-dark)}.bg-gradient-amber{background:var(--gradient-amber-glow)}.btn-fantasy-primary{background:var(--gradient-amber-button);color:#fff;transition:background var(--transition-fast) var(--ease-in-out)}.btn-fantasy-primary:hover{background:var(--gradient-amber-button-hover)}.texture-noise{position:relative;overflow:hidden}.texture-noise::before{content:"";position:absolute;inset:0;opacity:.03;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' /%3E%3C/svg%3E");pointer-events:none;z-index:1}.glow-amber{box-shadow:0 0 30px rgba(217,119,6,.3);transition:box-shadow var(--transition-fast) var(--ease-in-out)}.glow-amber:hover{box-shadow:0 0 40px rgba(217,119,6,.5)}.glow-amber-strong{box-shadow:0 0 40px rgba(217,119,6,.6)}.particles-container{position:relative;overflow:hidden}.stat-card{padding:var(--space-lg);background:var(--card-bg);border-radius:var(--radius-lg);border:var(--card-border-width) solid var(--card-border-color);box-shadow:var(--shadow-md)}.stat-card-fantasy{padding:var(--space-lg);background:var(--gradient-card-fantasy);border-radius:var(--radius-lg);border:2px solid rgba(217,119,6,.3);box-shadow:var(--shadow-lg);backdrop-filter:blur(10px)}.hp-bar{height:8px;background:rgba(200,200,200,.3);border-radius:var(--radius-full);overflow:hidden}.hp-bar-fill{height:100%;background:linear-gradient(90deg, #ef4444 0%, #dc2626 100%);transition:width var(--transition-base) var(--ease-in-out)}.hp-bar-fill.healthy{background:linear-gradient(90deg, #10b981 0%, #059669 100%)}.hp-bar-fill.wounded{background:linear-gradient(90deg, #f59e0b 0%, #d97706 100%)}.hp-bar-fill.critical{background:linear-gradient(90deg, #ef4444 0%, #dc2626 100%)}.badge-level{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:var(--font-xs);font-weight:var(--font-weight-semibold);background:var(--color-secondary);color:#fff;border-radius:var(--radius-full)}.badge-class{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:var(--font-xs);font-weight:var(--font-weight-medium);background:rgba(0,0,0,0);color:var(--text-primary);border:1px solid var(--color-gray-300);border-radius:var(--radius-full)}.character-card{background:#fff;border-radius:var(--radius-lg);border:2px solid rgba(139,92,246,.2);padding:var(--space-md);transition:all var(--transition-fast) var(--ease-in-out)}.character-card:hover{border-color:rgba(139,92,246,.4);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.party-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:var(--space-md)}@media(max-width: 768px){.hide-mobile{display:none !important}}@media(min-width: 769px){.hide-desktop{display:none !important}}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-base) var(--ease-out)}@keyframes sparkle{0%,100%{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}.animate-sparkle{animation:sparkle 3s var(--ease-in-out) infinite}@keyframes glow-pulse{0%,100%{box-shadow:0 0 20px rgba(217,119,6,.3)}50%{box-shadow:0 0 40px rgba(217,119,6,.6)}}.animate-glow-pulse{animation:glow-pulse 2s var(--ease-in-out) infinite}.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}.focus-visible-ring:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset);box-shadow:var(--focus-ring-shadow)}.btn-consistent,.quick-actions-bar .btn,.modal-footer .btn,.spell-card-actions .btn,.character-wizard .btn{min-height:var(--btn-height-md);min-width:var(--btn-min-width);padding:var(--btn-padding-md);font-size:var(--btn-font-md);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);border-radius:var(--radius-md);border:2px solid rgba(0,0,0,0);transition:all var(--transition-fast) var(--ease-in-out);cursor:pointer;user-select:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm)}.btn-consistent:focus-visible,.quick-actions-bar .btn:focus-visible,.modal-footer .btn:focus-visible,.spell-card-actions .btn:focus-visible,.character-wizard .btn:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset);box-shadow:var(--focus-ring-shadow)}.btn-consistent:hover:not(:disabled),.quick-actions-bar .btn:hover:not(:disabled),.modal-footer .btn:hover:not(:disabled),.spell-card-actions .btn:hover:not(:disabled),.character-wizard .btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-consistent:active:not(:disabled),.quick-actions-bar .btn:active:not(:disabled),.modal-footer .btn:active:not(:disabled),.spell-card-actions .btn:active:not(:disabled),.character-wizard .btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn-consistent:disabled,.quick-actions-bar .btn:disabled,.modal-footer .btn:disabled,.spell-card-actions .btn:disabled,.character-wizard .btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-consistent.btn-sm,.quick-actions-bar .btn-sm.btn,.modal-footer .btn-sm.btn,.spell-card-actions .btn-sm.btn,.character-wizard .btn-sm.btn{min-height:var(--btn-height-sm);padding:var(--btn-padding-sm);font-size:var(--btn-font-sm)}.btn-consistent.btn-lg,.quick-actions-bar .btn-lg.btn,.modal-footer .btn-lg.btn,.spell-card-actions .btn-lg.btn,.character-wizard .btn-lg.btn{min-height:var(--btn-height-lg);padding:var(--btn-padding-lg);font-size:var(--btn-font-lg)}.btn-consistent.btn-primary,.quick-actions-bar .btn-primary.btn,.modal-footer .btn-primary.btn,.spell-card-actions .btn-primary.btn,.character-wizard .btn-primary.btn{background:var(--gradient-purple);color:#fff;box-shadow:var(--shadow-sm)}.btn-consistent.btn-primary:hover:not(:disabled),.quick-actions-bar .btn-primary.btn:hover:not(:disabled),.modal-footer .btn-primary.btn:hover:not(:disabled),.spell-card-actions .btn-primary.btn:hover:not(:disabled),.character-wizard .btn-primary.btn:hover:not(:disabled){background:var(--gradient-gold);box-shadow:var(--shadow-lg)}.btn-consistent.btn-secondary,.quick-actions-bar .btn-secondary.btn,.modal-footer .btn-secondary.btn,.spell-card-actions .btn-secondary.btn,.character-wizard .btn-secondary.btn{background:var(--color-gray-100);color:var(--text-primary);border-color:var(--color-gray-300)}.btn-consistent.btn-secondary:hover:not(:disabled),.quick-actions-bar .btn-secondary.btn:hover:not(:disabled),.modal-footer .btn-secondary.btn:hover:not(:disabled),.spell-card-actions .btn-secondary.btn:hover:not(:disabled),.character-wizard .btn-secondary.btn:hover:not(:disabled){background:var(--color-gray-200);border-color:var(--color-gray-400)}.btn-consistent.btn-success,.quick-actions-bar .btn-success.btn,.modal-footer .btn-success.btn,.spell-card-actions .btn-success.btn,.character-wizard .btn-success.btn{background:var(--color-success);color:#fff}.btn-consistent.btn-success:hover:not(:disabled),.quick-actions-bar .btn-success.btn:hover:not(:disabled),.modal-footer .btn-success.btn:hover:not(:disabled),.spell-card-actions .btn-success.btn:hover:not(:disabled),.character-wizard .btn-success.btn:hover:not(:disabled){background:#059669}.btn-consistent.btn-danger,.quick-actions-bar .btn-danger.btn,.modal-footer .btn-danger.btn,.spell-card-actions .btn-danger.btn,.character-wizard .btn-danger.btn{background:var(--color-danger);color:#fff}.btn-consistent.btn-danger:hover:not(:disabled),.quick-actions-bar .btn-danger.btn:hover:not(:disabled),.modal-footer .btn-danger.btn:hover:not(:disabled),.spell-card-actions .btn-danger.btn:hover:not(:disabled),.character-wizard .btn-danger.btn:hover:not(:disabled){background:#dc2626}.btn-consistent.btn-gold,.quick-actions-bar .btn-gold.btn,.modal-footer .btn-gold.btn,.spell-card-actions .btn-gold.btn,.character-wizard .btn-gold.btn{background:var(--gradient-gold);color:#fff;box-shadow:0 0 10px rgba(212,175,55,.3)}.btn-consistent.btn-gold:hover:not(:disabled),.quick-actions-bar .btn-gold.btn:hover:not(:disabled),.modal-footer .btn-gold.btn:hover:not(:disabled),.spell-card-actions .btn-gold.btn:hover:not(:disabled),.character-wizard .btn-gold.btn:hover:not(:disabled){box-shadow:0 0 20px rgba(212,175,55,.5)}.btn-consistent.btn-outline,.quick-actions-bar .btn-outline.btn,.modal-footer .btn-outline.btn,.spell-card-actions .btn-outline.btn,.character-wizard .btn-outline.btn{background:rgba(0,0,0,0);border-color:var(--color-gray-300);color:var(--text-primary)}.btn-consistent.btn-outline:hover:not(:disabled),.quick-actions-bar .btn-outline.btn:hover:not(:disabled),.modal-footer .btn-outline.btn:hover:not(:disabled),.spell-card-actions .btn-outline.btn:hover:not(:disabled),.character-wizard .btn-outline.btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--color-gold)}.btn-consistent.btn-loading,.quick-actions-bar .btn-loading.btn,.modal-footer .btn-loading.btn,.spell-card-actions .btn-loading.btn,.character-wizard .btn-loading.btn{position:relative;color:rgba(0,0,0,0) !important;pointer-events:none}.btn-consistent.btn-loading::after,.quick-actions-bar .btn-loading.btn::after,.modal-footer .btn-loading.btn::after,.spell-card-actions .btn-loading.btn::after,.character-wizard .btn-loading.btn::after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid currentColor;border-radius:50%;border-right-color:rgba(0,0,0,0);animation:btn-spin .6s linear infinite;color:inherit}@keyframes btn-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.btn-consistent.btn-success-flash,.quick-actions-bar .btn-success-flash.btn,.modal-footer .btn-success-flash.btn,.spell-card-actions .btn-success-flash.btn,.character-wizard .btn-success-flash.btn{animation:btn-success-flash .8s var(--ease-out)}@keyframes btn-success-flash{0%{background-color:inherit}15%{background-color:var(--color-success);box-shadow:0 0 20px rgba(16,185,129,.6);transform:scale(1.05)}100%{background-color:inherit}}.card-rpg,.stat-card,.ability-scores-section,.combat-stats-section,.saving-throws-section,.skills-section,.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section{padding:var(--card-padding);background:var(--card-bg);backdrop-filter:var(--card-backdrop-filter);border-radius:var(--radius-lg);border:var(--card-border-width) solid var(--card-border-color);box-shadow:var(--shadow-md);transition:all var(--transition-base) var(--ease-in-out)}.card-rpg:hover,.stat-card:hover,.ability-scores-section:hover,.combat-stats-section:hover,.saving-throws-section:hover,.skills-section:hover,.features-section:hover,.personality-section:hover,.equipment-section:hover,.spells-section:hover,.backstory-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-rpg:focus-within,.stat-card:focus-within,.ability-scores-section:focus-within,.combat-stats-section:focus-within,.saving-throws-section:focus-within,.skills-section:focus-within,.features-section:focus-within,.personality-section:focus-within,.equipment-section:focus-within,.spells-section:focus-within,.backstory-section:focus-within{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.card-rpg-header{padding:var(--space-md) var(--space-lg);margin:calc(var(--card-padding)*-1) calc(var(--card-padding)*-1) var(--card-padding);background:var(--gradient-card-header);border-bottom:2px solid var(--color-gold);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.card-rpg-title{font-size:var(--font-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin:0;line-height:var(--line-height-tight)}.card-rpg-subtitle{font-size:var(--font-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin-top:var(--space-xs)}.card-rpg-body{color:var(--text-primary)}.card-rpg-footer{padding:var(--space-md) var(--space-lg);margin:var(--card-padding) calc(var(--card-padding)*-1) calc(var(--card-padding)*-1);background:var(--bg-secondary);border-top:1px solid var(--card-border-color);border-radius:0 0 var(--radius-lg) var(--radius-lg);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm)}.card-rpg.card-legendary,.card-legendary.stat-card,.card-legendary.ability-scores-section,.card-legendary.combat-stats-section,.card-legendary.saving-throws-section,.card-legendary.skills-section,.card-legendary.features-section,.card-legendary.personality-section,.card-legendary.equipment-section,.card-legendary.spells-section,.card-legendary.backstory-section{border-color:#ff9800;box-shadow:0 0 20px rgba(255,152,0,.3),var(--shadow-lg);animation:legendary-pulse 2s ease-in-out infinite}@keyframes legendary-pulse{0%,100%{box-shadow:0 0 20px rgba(255,152,0,.3),var(--shadow-lg)}50%{box-shadow:0 0 30px rgba(255,152,0,.6),var(--shadow-xl)}}.card-rpg.card-rare,.card-rare.stat-card,.card-rare.ability-scores-section,.card-rare.combat-stats-section,.card-rare.saving-throws-section,.card-rare.skills-section,.card-rare.features-section,.card-rare.personality-section,.card-rare.equipment-section,.card-rare.spells-section,.card-rare.backstory-section{border-color:#3b82f6;box-shadow:0 0 12px rgba(59,130,246,.2),var(--shadow-md)}.card-rpg.card-uncommon,.card-uncommon.stat-card,.card-uncommon.ability-scores-section,.card-uncommon.combat-stats-section,.card-uncommon.saving-throws-section,.card-uncommon.skills-section,.card-uncommon.features-section,.card-uncommon.personality-section,.card-uncommon.equipment-section,.card-uncommon.spells-section,.card-uncommon.backstory-section{border-color:#10b981;box-shadow:0 0 10px rgba(16,185,129,.2),var(--shadow-md)}.card-rpg.card-compact,.card-compact.stat-card,.card-compact.ability-scores-section,.card-compact.combat-stats-section,.card-compact.saving-throws-section,.card-compact.skills-section,.card-compact.features-section,.card-compact.personality-section,.card-compact.equipment-section,.card-compact.spells-section,.card-compact.backstory-section{padding:var(--space-md)}.card-rpg.card-elevated,.card-elevated.stat-card,.card-elevated.ability-scores-section,.card-elevated.combat-stats-section,.card-elevated.saving-throws-section,.card-elevated.skills-section,.card-elevated.features-section,.card-elevated.personality-section,.card-elevated.equipment-section,.card-elevated.spells-section,.card-elevated.backstory-section{box-shadow:var(--shadow-xl)}.stat-card{text-align:center;padding:var(--space-md);cursor:pointer}.stat-card:hover{border-color:var(--color-gold-dark);transform:translateY(-4px);box-shadow:var(--shadow-xl)}.stat-card-label{font-size:var(--font-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.stat-card-value{font-size:var(--font-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight);margin-bottom:var(--space-xs)}.stat-card-modifier{font-size:var(--font-lg);font-weight:var(--font-weight-semibold);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);display:inline-block}.stat-card-modifier.positive{color:var(--color-success);background:rgba(16,185,129,.1)}.stat-card-modifier.negative{color:var(--color-danger);background:rgba(239,68,68,.1)}.stat-card-modifier.neutral{color:var(--text-secondary);background:var(--bg-secondary)}.glassmorphic{background:hsla(0,0%,100%,.85);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.3)}.golden-accent{border-color:var(--color-gold);box-shadow:0 0 10px rgba(212,175,55,.2)}.equipped-indicator{border-left:4px solid var(--color-success);background:rgba(16,185,129,.05)}.attuned-indicator{border-left:4px solid var(--color-purple);background:rgba(139,92,246,.05);box-shadow:0 0 15px rgba(139,92,246,.2)}@media(max-width: 768px){.card-rpg,.ability-scores-section,.combat-stats-section,.saving-throws-section,.skills-section,.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section,.stat-card{padding:var(--space-md)}.card-rpg-header,.card-rpg-footer{padding:var(--space-sm) var(--space-md)}.card-rpg-title{font-size:var(--font-lg)}.btn-consistent,.quick-actions-bar .btn,.modal-footer .btn,.spell-card-actions .btn,.character-wizard .btn{padding:var(--space-sm) var(--space-md)}}@media(hover: none)and (pointer: coarse){.btn-consistent,.quick-actions-bar .btn,.modal-footer .btn,.spell-card-actions .btn,.character-wizard .btn{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}.stat-card{min-height:60px;padding:var(--space-md)}}[data-theme=dark] .btn-consistent.btn-primary,[data-theme=dark] .quick-actions-bar .btn-primary.btn,.quick-actions-bar [data-theme=dark] .btn-primary.btn,[data-theme=dark] .modal-footer .btn-primary.btn,.modal-footer [data-theme=dark] .btn-primary.btn,[data-theme=dark] .spell-card-actions .btn-primary.btn,.spell-card-actions [data-theme=dark] .btn-primary.btn,[data-theme=dark] .character-wizard .btn-primary.btn,.character-wizard [data-theme=dark] .btn-primary.btn{background:var(--gradient-purple);box-shadow:0 0 15px rgba(139,92,246,.4)}[data-theme=dark] .btn-consistent.btn-secondary,[data-theme=dark] .quick-actions-bar .btn-secondary.btn,.quick-actions-bar [data-theme=dark] .btn-secondary.btn,[data-theme=dark] .modal-footer .btn-secondary.btn,.modal-footer [data-theme=dark] .btn-secondary.btn,[data-theme=dark] .spell-card-actions .btn-secondary.btn,.spell-card-actions [data-theme=dark] .btn-secondary.btn,[data-theme=dark] .character-wizard .btn-secondary.btn,.character-wizard [data-theme=dark] .btn-secondary.btn{background:#334155;color:#e2e8f0;border-color:#475569}[data-theme=dark] .btn-consistent.btn-secondary:hover:not(:disabled),[data-theme=dark] .quick-actions-bar .btn-secondary.btn:hover:not(:disabled),.quick-actions-bar [data-theme=dark] .btn-secondary.btn:hover:not(:disabled),[data-theme=dark] .modal-footer .btn-secondary.btn:hover:not(:disabled),.modal-footer [data-theme=dark] .btn-secondary.btn:hover:not(:disabled),[data-theme=dark] .spell-card-actions .btn-secondary.btn:hover:not(:disabled),.spell-card-actions [data-theme=dark] .btn-secondary.btn:hover:not(:disabled),[data-theme=dark] .character-wizard .btn-secondary.btn:hover:not(:disabled),.character-wizard [data-theme=dark] .btn-secondary.btn:hover:not(:disabled){background:#475569;border-color:#64748b}[data-theme=dark] .btn-consistent.btn-outline,[data-theme=dark] .quick-actions-bar .btn-outline.btn,.quick-actions-bar [data-theme=dark] .btn-outline.btn,[data-theme=dark] .modal-footer .btn-outline.btn,.modal-footer [data-theme=dark] .btn-outline.btn,[data-theme=dark] .spell-card-actions .btn-outline.btn,.spell-card-actions [data-theme=dark] .btn-outline.btn,[data-theme=dark] .character-wizard .btn-outline.btn,.character-wizard [data-theme=dark] .btn-outline.btn{background:rgba(0,0,0,0);border-color:#475569;color:#e2e8f0}[data-theme=dark] .btn-consistent.btn-outline:hover:not(:disabled),[data-theme=dark] .quick-actions-bar .btn-outline.btn:hover:not(:disabled),.quick-actions-bar [data-theme=dark] .btn-outline.btn:hover:not(:disabled),[data-theme=dark] .modal-footer .btn-outline.btn:hover:not(:disabled),.modal-footer [data-theme=dark] .btn-outline.btn:hover:not(:disabled),[data-theme=dark] .spell-card-actions .btn-outline.btn:hover:not(:disabled),.spell-card-actions [data-theme=dark] .btn-outline.btn:hover:not(:disabled),[data-theme=dark] .character-wizard .btn-outline.btn:hover:not(:disabled),.character-wizard [data-theme=dark] .btn-outline.btn:hover:not(:disabled){background:#1e293b;border-color:#d4af37}[data-theme=dark] .card-rpg,[data-theme=dark] .ability-scores-section,[data-theme=dark] .combat-stats-section,[data-theme=dark] .saving-throws-section,[data-theme=dark] .skills-section,[data-theme=dark] .features-section,[data-theme=dark] .personality-section,[data-theme=dark] .equipment-section,[data-theme=dark] .spells-section,[data-theme=dark] .backstory-section,[data-theme=dark] .stat-card{background:linear-gradient(135deg, rgba(30, 41, 59, 0.95) 0%, rgba(15, 23, 42, 0.95) 100%);border-color:rgba(139,92,246,.3)}[data-theme=dark] .card-rpg:hover,[data-theme=dark] .ability-scores-section:hover,[data-theme=dark] .combat-stats-section:hover,[data-theme=dark] .saving-throws-section:hover,[data-theme=dark] .skills-section:hover,[data-theme=dark] .features-section:hover,[data-theme=dark] .personality-section:hover,[data-theme=dark] .equipment-section:hover,[data-theme=dark] .spells-section:hover,[data-theme=dark] .backstory-section:hover,[data-theme=dark] .stat-card:hover{box-shadow:0 0 20px rgba(139,92,246,.3),var(--shadow-lg)}[data-theme=dark] .card-rpg-header{background:linear-gradient(135deg, rgba(212, 175, 55, 0.15) 0%, rgba(245, 158, 11, 0.1) 100%);border-bottom-color:#d97706}[data-theme=dark] .card-rpg-title{color:#f1f5f9}[data-theme=dark] .card-rpg-subtitle{color:#94a3b8}[data-theme=dark] .card-rpg-body{color:#f1f5f9}[data-theme=dark] .card-rpg-footer{background:#0f172a;border-top-color:rgba(139,92,246,.2)}[data-theme=dark] .stat-card{background:#1e293b;border-color:#334155}[data-theme=dark] .stat-card:hover{border-color:#8b5cf6;box-shadow:0 0 20px rgba(139,92,246,.3),var(--shadow-xl)}[data-theme=dark] .stat-card-label{color:#94a3b8}[data-theme=dark] .stat-card-value{color:#f1f5f9}[data-theme=dark] .stat-card-modifier.positive{color:#6ee7b7;background:rgba(16,185,129,.15)}[data-theme=dark] .stat-card-modifier.negative{color:#fca5a5;background:rgba(239,68,68,.15)}[data-theme=dark] .glassmorphic{background:rgba(30,41,59,.85);backdrop-filter:blur(10px);border-color:rgba(71,85,105,.3)}[data-theme=dark] .golden-accent{border-color:#d4af37;box-shadow:0 0 15px rgba(212,175,55,.3)}[data-theme=dark] .equipped-indicator{border-left-color:#6ee7b7;background:rgba(16,185,129,.1)}[data-theme=dark] .attuned-indicator{border-left-color:#a78bfa;background:rgba(139,92,246,.1);box-shadow:0 0 20px rgba(139,92,246,.3)}[data-theme=dark] .card-rpg.card-legendary,[data-theme=dark] .card-legendary.ability-scores-section,[data-theme=dark] .card-legendary.combat-stats-section,[data-theme=dark] .card-legendary.saving-throws-section,[data-theme=dark] .card-legendary.skills-section,[data-theme=dark] .card-legendary.features-section,[data-theme=dark] .card-legendary.personality-section,[data-theme=dark] .card-legendary.equipment-section,[data-theme=dark] .card-legendary.spells-section,[data-theme=dark] .card-legendary.backstory-section,[data-theme=dark] .card-legendary.stat-card{border-color:#fb923c;box-shadow:0 0 25px rgba(251,146,60,.4),var(--shadow-lg)}[data-theme=dark] .card-rpg.card-rare,[data-theme=dark] .card-rare.ability-scores-section,[data-theme=dark] .card-rare.combat-stats-section,[data-theme=dark] .card-rare.saving-throws-section,[data-theme=dark] .card-rare.skills-section,[data-theme=dark] .card-rare.features-section,[data-theme=dark] .card-rare.personality-section,[data-theme=dark] .card-rare.equipment-section,[data-theme=dark] .card-rare.spells-section,[data-theme=dark] .card-rare.backstory-section,[data-theme=dark] .card-rare.stat-card{border-color:#60a5fa;box-shadow:0 0 15px rgba(96,165,250,.3),var(--shadow-md)}[data-theme=dark] .card-rpg.card-uncommon,[data-theme=dark] .card-uncommon.ability-scores-section,[data-theme=dark] .card-uncommon.combat-stats-section,[data-theme=dark] .card-uncommon.saving-throws-section,[data-theme=dark] .card-uncommon.skills-section,[data-theme=dark] .card-uncommon.features-section,[data-theme=dark] .card-uncommon.personality-section,[data-theme=dark] .card-uncommon.equipment-section,[data-theme=dark] .card-uncommon.spells-section,[data-theme=dark] .card-uncommon.backstory-section,[data-theme=dark] .card-uncommon.stat-card{border-color:#6ee7b7;box-shadow:0 0 12px rgba(110,231,183,.3),var(--shadow-md)}@media print{.card-rpg,.ability-scores-section,.combat-stats-section,.saving-throws-section,.skills-section,.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section,.stat-card{break-inside:avoid;page-break-inside:avoid;box-shadow:none !important;animation:none !important}.btn-consistent,.quick-actions-bar .btn,.modal-footer .btn,.spell-card-actions .btn,.character-wizard .btn{display:none !important}.card-rpg:hover,.ability-scores-section:hover,.combat-stats-section:hover,.saving-throws-section:hover,.skills-section:hover,.features-section:hover,.personality-section:hover,.equipment-section:hover,.spells-section:hover,.backstory-section:hover,.stat-card:hover{transform:none !important;box-shadow:none !important}}@media(prefers-reduced-motion: reduce){.card-rpg,.ability-scores-section,.combat-stats-section,.saving-throws-section,.skills-section,.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section,.stat-card,.btn-consistent,.quick-actions-bar .btn,.modal-footer .btn,.spell-card-actions .btn,.character-wizard .btn{transition:none !important;animation:none !important}.card-rpg:hover,.ability-scores-section:hover,.combat-stats-section:hover,.saving-throws-section:hover,.skills-section:hover,.features-section:hover,.personality-section:hover,.equipment-section:hover,.spells-section:hover,.backstory-section:hover,.stat-card:hover,.btn-consistent:hover,.quick-actions-bar .btn:hover,.modal-footer .btn:hover,.spell-card-actions .btn:hover,.character-wizard .btn:hover{transform:none !important}}@media(prefers-contrast: high){.card-rpg,.ability-scores-section,.combat-stats-section,.saving-throws-section,.skills-section,.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section,.stat-card{border-width:3px}.btn-consistent,.quick-actions-bar .btn,.modal-footer .btn,.spell-card-actions .btn,.character-wizard .btn{border-width:3px}}.hero-banner{position:relative;min-height:80vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--gradient-primary)}.hero-banner::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.1) 100%);z-index:1}.hero-banner .hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:2rem}.hero-banner .hero-content h1{font-size:clamp(2rem,5vw,4rem);font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.hero-banner.animate-fade-in{animation:fadeIn .5s ease-in-out}.hero-banner.animate-slide-up{animation:slideUp .3s ease-out}.hero-banner[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.hero-banner[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.hero-banner[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.hero-banner[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.hero-banner[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.hero-banner[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@media(max-width: 768px){.hero-banner{min-height:60vh}.hero-banner .hero-content{padding:1rem}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.smooth-scroll.animate-fade-in{animation:fadeIn .5s ease-in-out}.smooth-scroll.animate-slide-up{animation:slideUp .3s ease-out}.smooth-scroll[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.smooth-scroll[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.smooth-scroll[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.smooth-scroll[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.smooth-scroll[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.smooth-scroll[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.modal-system{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.modal-system.active{opacity:1;visibility:visible}.modal-system .modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}.modal-system .modal-content{position:relative;background:#fff;border-radius:16px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;transform:scale(0.9);transition:transform .3s}.modal-system.active .modal-content{transform:scale(1)}.modal-system.animate-fade-in{animation:fadeIn .5s ease-in-out}.modal-system.animate-slide-up{animation:slideUp .3s ease-out}.modal-system[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.modal-system[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.modal-system[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.modal-system[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.modal-system[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.modal-system[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.modal-backdrop{z-index:1040 !important}.modal{z-index:1050 !important}.modal .modal-dialog.modal-dialog-centered{display:flex;align-items:center;min-height:calc(100% - 1rem)}body.modal-open{overflow:hidden}.toast-notifications.animate-fade-in{animation:fadeIn .5s ease-in-out}.toast-notifications.animate-slide-up{animation:slideUp .3s ease-out}.toast-notifications[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.toast-notifications[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.toast-notifications[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.toast-notifications[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.toast-notifications[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.toast-notifications[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.lazy-loader.animate-fade-in{animation:fadeIn .5s ease-in-out}.lazy-loader.animate-slide-up{animation:slideUp .3s ease-out}.lazy-loader[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.lazy-loader[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.lazy-loader[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.lazy-loader[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.lazy-loader[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.lazy-loader[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.dark-mode-toggle.animate-fade-in{animation:fadeIn .5s ease-in-out}.dark-mode-toggle.animate-slide-up{animation:slideUp .3s ease-out}.dark-mode-toggle[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.dark-mode-toggle[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.dark-mode-toggle[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.dark-mode-toggle[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.dark-mode-toggle[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.dark-mode-toggle[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.search-spotlight.animate-fade-in{animation:fadeIn .5s ease-in-out}.search-spotlight.animate-slide-up{animation:slideUp .3s ease-out}.search-spotlight[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.search-spotlight[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.search-spotlight[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.search-spotlight[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.search-spotlight[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.search-spotlight[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.data-charts.animate-fade-in{animation:fadeIn .5s ease-in-out}.data-charts.animate-slide-up{animation:slideUp .3s ease-out}.data-charts[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.data-charts[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.data-charts[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.data-charts[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.data-charts[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.data-charts[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.stat-cards.animate-fade-in{animation:fadeIn .5s ease-in-out}.stat-cards.animate-slide-up{animation:slideUp .3s ease-out}.stat-cards[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.stat-cards[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.stat-cards[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.stat-cards[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.stat-cards[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.stat-cards[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.activity-timeline.animate-fade-in{animation:fadeIn .5s ease-in-out}.activity-timeline.animate-slide-up{animation:slideUp .3s ease-out}.activity-timeline[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.activity-timeline[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.activity-timeline[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.activity-timeline[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.activity-timeline[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.activity-timeline[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.command-palette.animate-fade-in{animation:fadeIn .5s ease-in-out}.command-palette.animate-slide-up{animation:slideUp .3s ease-out}.command-palette[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.command-palette[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.command-palette[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.command-palette[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.command-palette[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.command-palette[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.realtime-indicator.animate-fade-in{animation:fadeIn .5s ease-in-out}.realtime-indicator.animate-slide-up{animation:slideUp .3s ease-out}.realtime-indicator[data-theme=ecommerce]{--primary: #2563eb;--secondary: #b45309;--accent: #ec4899;--gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.realtime-indicator[data-theme=saas]{--primary: #3b82f6;--secondary: #10b981;--accent: #f59e0b;--gradient: linear-gradient(135deg, #667eea 0%, #3b82f6 100%)}.realtime-indicator[data-theme=food_beverage]{--primary: #f97316;--secondary: #84cc16;--accent: #ef4444;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.realtime-indicator[data-theme=social]{--primary: #d97706;--secondary: #ec4899;--accent: #06b6d4;--gradient: linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.realtime-indicator[data-theme=gaming]{--primary: #a855f7;--secondary: #06b6d4;--accent: #f97316;--gradient: linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.realtime-indicator[data-theme=healthcare]{--primary: #10b981;--secondary: #06b6d4;--accent: #3b82f6;--gradient: linear-gradient(135deg, #89f7fe 0%, #66a6ff 100%)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.spellbook-container{max-width:1400px;margin:0 auto;padding:1rem}@media(min-width: 768px){.spellbook-container{padding:2rem}}.spell-filter-panel{background:linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.95) 100%);backdrop-filter:blur(10px);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem;box-shadow:var(--shadow-lg);border:1px solid rgba(226,232,240,.8);transition:all var(--transition-base)}.spell-filter-panel:hover{box-shadow:var(--shadow-xl);transform:translateY(-2px)}[data-theme=dark] .spell-filter-panel{background:linear-gradient(135deg, rgba(30, 41, 59, 0.95) 0%, rgba(15, 23, 42, 0.95) 100%);border-color:rgba(71,85,105,.6)}.filter-section{margin-bottom:1.5rem}.filter-section:last-child{margin-bottom:0}.filter-section h3{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}[data-theme=dark] .filter-section h3{color:#94a3b8}.filter-section h3::before{content:"";width:3px;height:1rem;background:var(--primary);border-radius:2px}.filter-chips{display:flex;flex-wrap:wrap;gap:.5rem}.filter-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:#fff;border:2px solid #e2e8f0;border-radius:var(--radius-full);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);user-select:none}.filter-chip:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-md)}.filter-chip.active .filter-chip-icon{color:#fff}[data-theme=dark] .filter-chip{background:#1e293b;border-color:#334155;color:#e2e8f0}[data-theme=dark] .filter-chip:hover{border-color:var(--primary)}[data-theme=dark] .filter-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.filter-chip-icon{font-size:1rem;color:#64748b;transition:color var(--transition-fast)}.filter-chip[data-school=abjuration].active{background:#3b82f6;border-color:#3b82f6}[data-theme=dark] .filter-chip[data-school=abjuration].active{background:#1e3a8a;border-color:#3b82f6}.filter-chip[data-school=abjuration] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#3b82f6;border:2px solid #fff;box-shadow:0 0 0 1px #93c5fd}.filter-chip[data-school=conjuration].active{background:#a855f7;border-color:#a855f7}[data-theme=dark] .filter-chip[data-school=conjuration].active{background:#581c87;border-color:#a855f7}.filter-chip[data-school=conjuration] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#a855f7;border:2px solid #fff;box-shadow:0 0 0 1px #d8b4fe}.filter-chip[data-school=divination].active{background:#94a3b8;border-color:#94a3b8}[data-theme=dark] .filter-chip[data-school=divination].active{background:#334155;border-color:#94a3b8}.filter-chip[data-school=divination] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#94a3b8;border:2px solid #fff;box-shadow:0 0 0 1px #cbd5e1}.filter-chip[data-school=enchantment].active{background:#ec4899;border-color:#ec4899}[data-theme=dark] .filter-chip[data-school=enchantment].active{background:#831843;border-color:#ec4899}.filter-chip[data-school=enchantment] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#ec4899;border:2px solid #fff;box-shadow:0 0 0 1px #f9a8d4}.filter-chip[data-school=evocation].active{background:#ef4444;border-color:#ef4444}[data-theme=dark] .filter-chip[data-school=evocation].active{background:#991b1b;border-color:#ef4444}.filter-chip[data-school=evocation] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#ef4444;border:2px solid #fff;box-shadow:0 0 0 1px #fca5a5}.filter-chip[data-school=illusion].active{background:#8b5cf6;border-color:#8b5cf6}[data-theme=dark] .filter-chip[data-school=illusion].active{background:#5b21b6;border-color:#8b5cf6}.filter-chip[data-school=illusion] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#8b5cf6;border:2px solid #fff;box-shadow:0 0 0 1px #c4b5fd}.filter-chip[data-school=necromancy].active{background:#22c55e;border-color:#22c55e}[data-theme=dark] .filter-chip[data-school=necromancy].active{background:#15803d;border-color:#22c55e}.filter-chip[data-school=necromancy] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#22c55e;border:2px solid #fff;box-shadow:0 0 0 1px #86efac}.filter-chip[data-school=transmutation].active{background:#f97316;border-color:#f97316}[data-theme=dark] .filter-chip[data-school=transmutation].active{background:#c2410c;border-color:#f97316}.filter-chip[data-school=transmutation] .school-indicator{width:1rem;height:1rem;border-radius:50%;background:#f97316;border:2px solid #fff;box-shadow:0 0 0 1px #fdba74}.spell-search-container{position:relative;margin-bottom:1.5rem}.spell-search-input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:var(--radius-lg);font-size:1rem;transition:all var(--transition-base);background:#fff}.spell-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}.spell-search-input::placeholder{color:#94a3b8}[data-theme=dark] .spell-search-input{background:#1e293b;border-color:#334155;color:#e2e8f0}[data-theme=dark] .spell-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.2)}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.25rem;pointer-events:none}.search-results-count{position:absolute;right:1rem;top:50%;transform:translateY(-50%);padding:.25rem .75rem;background:#f1f5f9;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:#64748b}[data-theme=dark] .search-results-count{background:#334155;color:#94a3b8}.spells-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.25rem;margin-bottom:2rem}@media(max-width: 768px){.spells-grid{grid-template-columns:1fr;gap:1rem}}.spell-card{position:relative;background:#fff;border-radius:var(--radius-lg);border:2px solid #e2e8f0;overflow:hidden;transition:all var(--transition-base);cursor:pointer}.spell-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#cbd5e1}.spell-card:hover .spell-card-header{background-size:110%}.spell-card.prepared{border-color:#22c55e;box-shadow:0 0 0 1px #22c55e}.spell-card.prepared .spell-card-header::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg, #22c55e 0%, #16a34a 100%)}.spell-card.comparing{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.spell-card.favorited .favorite-badge{color:#fbbf24;opacity:1}[data-theme=dark] .spell-card{background:#1e293b;border-color:#334155}[data-theme=dark] .spell-card:hover{border-color:#475569}[data-theme=dark] .spell-card.prepared{border-color:#22c55e}.spell-card-header{position:relative;padding:1rem;background:linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);background-size:100%;transition:background-size var(--transition-slow)}[data-theme=dark] .spell-card-header{background:linear-gradient(135deg, #0f172a 0%, #1e293b 100%)}.spell-card[data-school=abjuration] .spell-card-header{background:linear-gradient(135deg, #dbeafe 0%, white 100%);border-bottom:2px solid #3b82f6}[data-theme=dark] .spell-card[data-school=abjuration] .spell-card-header{background:linear-gradient(135deg, #1e3a8a 0%, #1e293b 100%)}.spell-card[data-school=abjuration] .school-badge{background:#3b82f6;color:#fff}.spell-card[data-school=abjuration] .spell-level-indicator{background:#dbeafe;color:#3b82f6;border-color:#93c5fd}[data-theme=dark] .spell-card[data-school=abjuration] .spell-level-indicator{background:#1e3a8a;color:#fff}.spell-card[data-school=conjuration] .spell-card-header{background:linear-gradient(135deg, #f3e8ff 0%, white 100%);border-bottom:2px solid #a855f7}[data-theme=dark] .spell-card[data-school=conjuration] .spell-card-header{background:linear-gradient(135deg, #581c87 0%, #1e293b 100%)}.spell-card[data-school=conjuration] .school-badge{background:#a855f7;color:#fff}.spell-card[data-school=conjuration] .spell-level-indicator{background:#f3e8ff;color:#a855f7;border-color:#d8b4fe}[data-theme=dark] .spell-card[data-school=conjuration] .spell-level-indicator{background:#581c87;color:#fff}.spell-card[data-school=divination] .spell-card-header{background:linear-gradient(135deg, #f1f5f9 0%, white 100%);border-bottom:2px solid #94a3b8}[data-theme=dark] .spell-card[data-school=divination] .spell-card-header{background:linear-gradient(135deg, #334155 0%, #1e293b 100%)}.spell-card[data-school=divination] .school-badge{background:#94a3b8;color:#fff}.spell-card[data-school=divination] .spell-level-indicator{background:#f1f5f9;color:#94a3b8;border-color:#cbd5e1}[data-theme=dark] .spell-card[data-school=divination] .spell-level-indicator{background:#334155;color:#fff}.spell-card[data-school=enchantment] .spell-card-header{background:linear-gradient(135deg, #fce7f3 0%, white 100%);border-bottom:2px solid #ec4899}[data-theme=dark] .spell-card[data-school=enchantment] .spell-card-header{background:linear-gradient(135deg, #831843 0%, #1e293b 100%)}.spell-card[data-school=enchantment] .school-badge{background:#ec4899;color:#fff}.spell-card[data-school=enchantment] .spell-level-indicator{background:#fce7f3;color:#ec4899;border-color:#f9a8d4}[data-theme=dark] .spell-card[data-school=enchantment] .spell-level-indicator{background:#831843;color:#fff}.spell-card[data-school=evocation] .spell-card-header{background:linear-gradient(135deg, #fee2e2 0%, white 100%);border-bottom:2px solid #ef4444}[data-theme=dark] .spell-card[data-school=evocation] .spell-card-header{background:linear-gradient(135deg, #991b1b 0%, #1e293b 100%)}.spell-card[data-school=evocation] .school-badge{background:#ef4444;color:#fff}.spell-card[data-school=evocation] .spell-level-indicator{background:#fee2e2;color:#ef4444;border-color:#fca5a5}[data-theme=dark] .spell-card[data-school=evocation] .spell-level-indicator{background:#991b1b;color:#fff}.spell-card[data-school=illusion] .spell-card-header{background:linear-gradient(135deg, #ede9fe 0%, white 100%);border-bottom:2px solid #8b5cf6}[data-theme=dark] .spell-card[data-school=illusion] .spell-card-header{background:linear-gradient(135deg, #5b21b6 0%, #1e293b 100%)}.spell-card[data-school=illusion] .school-badge{background:#8b5cf6;color:#fff}.spell-card[data-school=illusion] .spell-level-indicator{background:#ede9fe;color:#8b5cf6;border-color:#c4b5fd}[data-theme=dark] .spell-card[data-school=illusion] .spell-level-indicator{background:#5b21b6;color:#fff}.spell-card[data-school=necromancy] .spell-card-header{background:linear-gradient(135deg, #dcfce7 0%, white 100%);border-bottom:2px solid #22c55e}[data-theme=dark] .spell-card[data-school=necromancy] .spell-card-header{background:linear-gradient(135deg, #15803d 0%, #1e293b 100%)}.spell-card[data-school=necromancy] .school-badge{background:#22c55e;color:#fff}.spell-card[data-school=necromancy] .spell-level-indicator{background:#dcfce7;color:#22c55e;border-color:#86efac}[data-theme=dark] .spell-card[data-school=necromancy] .spell-level-indicator{background:#15803d;color:#fff}.spell-card[data-school=transmutation] .spell-card-header{background:linear-gradient(135deg, #ffedd5 0%, white 100%);border-bottom:2px solid #f97316}[data-theme=dark] .spell-card[data-school=transmutation] .spell-card-header{background:linear-gradient(135deg, #c2410c 0%, #1e293b 100%)}.spell-card[data-school=transmutation] .school-badge{background:#f97316;color:#fff}.spell-card[data-school=transmutation] .spell-level-indicator{background:#ffedd5;color:#f97316;border-color:#fdba74}[data-theme=dark] .spell-card[data-school=transmutation] .spell-level-indicator{background:#c2410c;color:#fff}.spell-card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.spell-name{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0;line-height:1.3}[data-theme=dark] .spell-name{color:#f1f5f9}.spell-level-indicator{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:#f1f5f9;border:2px solid #e2e8f0;border-radius:50%;font-size:.875rem;font-weight:700;color:#475569}.spell-level-indicator.cantrip{background:linear-gradient(135deg, #a855f7 0%, #8b5cf6 100%);color:#fff;border-color:#c084fc}.spell-meta-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.school-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:#64748b;color:#fff;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:capitalize}.spell-badges{display:flex;flex-wrap:wrap;gap:.375rem}.spell-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;color:#475569}.spell-badge.ritual{background:#fef3c7;border-color:#fde047;color:#92400e}.spell-badge.concentration{background:#dbeafe;border-color:#93c5fd;color:#1e40af}[data-theme=dark] .spell-badge{background:#334155;border-color:#475569;color:#cbd5e1}[data-theme=dark] .spell-badge.ritual{background:#78350f;border-color:#ca8a04;color:#fef3c7}[data-theme=dark] .spell-badge.concentration{background:#1e3a8a;border-color:#3b82f6;color:#dbeafe}.spell-card-body{padding:1rem}.spell-stats-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:.75rem;margin-bottom:.875rem}@media(max-width: 480px){.spell-stats-grid{grid-template-columns:1fr;gap:.5rem}}.spell-stat{display:flex;align-items:flex-start;gap:.5rem}.spell-stat .stat-icon{flex-shrink:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:.875rem}.spell-stat .stat-content{flex:1;min-width:0}.spell-stat .stat-content .stat-label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;color:#94a3b8;margin-bottom:.125rem}.spell-stat .stat-content .stat-value{display:block;font-size:.875rem;font-weight:600;color:#1e293b;word-wrap:break-word}[data-theme=dark] .spell-stat .stat-content .stat-value{color:#e2e8f0}.spell-description{margin-bottom:1rem}.spell-description-preview{font-size:.875rem;line-height:1.5;color:#475569;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}[data-theme=dark] .spell-description-preview{color:#94a3b8}.spell-description-preview.expanded{display:block;-webkit-line-clamp:unset}.expand-description-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem 0;background:none;border:none;color:var(--primary);font-size:.75rem;font-weight:600;cursor:pointer;margin-top:.5rem;transition:color var(--transition-fast)}.expand-description-btn:hover{color:#2563eb;text-decoration:underline}.expand-description-btn .expand-icon{transition:transform var(--transition-fast)}.expand-description-btn.expanded .expand-icon{transform:rotate(180deg)}.spell-damage{padding:.75rem;background:linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);border:1px solid #fecaca;border-radius:var(--radius-md);margin-bottom:1rem}[data-theme=dark] .spell-damage{background:linear-gradient(135deg, #7f1d1d 0%, #991b1b 100%);border-color:#dc2626}.spell-damage .damage-label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;color:#991b1b;margin-bottom:.375rem}[data-theme=dark] .spell-damage .damage-label{color:#fecaca}.spell-damage .damage-dice{font-size:1.25rem;font-weight:800;font-family:"Courier New",monospace;color:#dc2626}[data-theme=dark] .spell-damage .damage-dice{color:#fca5a5}.spell-damage .damage-type{font-size:.75rem;font-weight:600;color:#7f1d1d;margin-left:.5rem}[data-theme=dark] .spell-damage .damage-type{color:#fecaca}.spell-card-actions{display:flex;gap:.5rem;padding:.75rem 1rem;background:#f8fafc;border-top:1px solid #e2e8f0}[data-theme=dark] .spell-card-actions{background:#0f172a;border-top-color:#334155}.spell-action-btn{flex:1;padding:.5rem 1rem;border:2px solid rgba(0,0,0,0);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:.375rem}.spell-action-btn.prepare-btn{background:var(--primary);color:#fff}.spell-action-btn.prepare-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:var(--shadow-md)}.spell-action-btn.prepare-btn:disabled{opacity:.5;cursor:not-allowed}.spell-action-btn.unprepare-btn{background:#f59e0b;color:#fff}.spell-action-btn.unprepare-btn:hover{background:#d97706;transform:translateY(-1px);box-shadow:var(--shadow-md)}.spell-action-btn.favorite-btn{flex:0 0 auto;width:2.5rem;background:#fff;border-color:#e2e8f0;color:#94a3b8}.spell-action-btn.favorite-btn:hover{border-color:#fbbf24;color:#fbbf24}.spell-action-btn.favorite-btn.active{background:#fef3c7;border-color:#fbbf24;color:#f59e0b}[data-theme=dark] .spell-action-btn.favorite-btn{background:#1e293b;border-color:#334155}[data-theme=dark] .spell-action-btn.favorite-btn.active{background:#78350f;border-color:#fbbf24;color:#fbbf24}.spell-action-btn.compare-btn{flex:0 0 auto;width:2.5rem;background:#fff;border-color:#e2e8f0;color:#94a3b8}.spell-action-btn.compare-btn:hover{border-color:var(--accent);color:var(--accent)}.spell-action-btn.compare-btn.active{background:#fef3c7;border-color:var(--accent);color:var(--accent)}[data-theme=dark] .spell-action-btn.compare-btn{background:#1e293b;border-color:#334155}[data-theme=dark] .spell-action-btn.compare-btn.active{background:#78350f;border-color:var(--accent);color:var(--accent)}.spell-comparison-container{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:3px solid var(--accent);box-shadow:0 -10px 40px rgba(0,0,0,.15);padding:1.5rem;transform:translateY(100%);transition:transform var(--transition-slow);z-index:1000;max-height:60vh;overflow-y:auto}.spell-comparison-container.active{transform:translateY(0)}[data-theme=dark] .spell-comparison-container{background:#1e293b;border-top-color:var(--accent)}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.comparison-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#0f172a}[data-theme=dark] .comparison-header h3{color:#f1f5f9}.comparison-header .close-comparison-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.comparison-header .close-comparison-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-md)}.comparison-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1.5rem}@media(max-width: 768px){.comparison-grid{grid-template-columns:1fr}}.comparison-spell-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:var(--radius-lg);padding:1.25rem}[data-theme=dark] .comparison-spell-card{background:#0f172a;border-color:#334155}.comparison-spell-card .comparison-spell-name{font-size:1.125rem;font-weight:700;margin-bottom:1rem;color:#0f172a}[data-theme=dark] .comparison-spell-card .comparison-spell-name{color:#f1f5f9}.comparison-spell-card .comparison-stat-row{display:flex;justify-content:space-between;padding:.625rem 0;border-bottom:1px solid #e2e8f0}.comparison-spell-card .comparison-stat-row:last-child{border-bottom:none}[data-theme=dark] .comparison-spell-card .comparison-stat-row{border-bottom-color:#334155}.comparison-spell-card .comparison-stat-row .stat-label{font-size:.875rem;font-weight:600;color:#64748b}.comparison-spell-card .comparison-stat-row .stat-value{font-size:.875rem;font-weight:700;color:#0f172a}[data-theme=dark] .comparison-spell-card .comparison-stat-row .stat-value{color:#e2e8f0}.comparison-spell-card .comparison-stat-row.different{background:#fef3c7;margin:0 -0.625rem;padding-left:.625rem;padding-right:.625rem}[data-theme=dark] .comparison-spell-card .comparison-stat-row.different{background:#78350f}.spellbook-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#f8fafc;border-radius:var(--radius-lg);border:1px solid #e2e8f0}[data-theme=dark] .spellbook-toolbar{background:#0f172a;border-color:#334155}.toolbar-group{display:flex;align-items:center;gap:.75rem}.toolbar-group label{font-size:.875rem;font-weight:600;color:#475569;margin:0}[data-theme=dark] .toolbar-group label{color:#94a3b8}.toolbar-group select{padding:.5rem 2.5rem .5rem .75rem;border:2px solid #e2e8f0;border-radius:var(--radius-md);background:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2364748b'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:1.25rem}.toolbar-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(59,130,246,.1)}[data-theme=dark] .toolbar-group select{background:#1e293b;border-color:#334155;color:#e2e8f0}.clear-filters-btn{padding:.5rem 1rem;background:#ef4444;color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:.375rem}.clear-filters-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-md)}.clear-filters-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.empty-state{text-align:center;padding:4rem 2rem}.empty-state .empty-state-icon{font-size:4rem;color:#cbd5e1;margin-bottom:1rem}[data-theme=dark] .empty-state .empty-state-icon{color:#475569}.empty-state .empty-state-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}[data-theme=dark] .empty-state .empty-state-title{color:#e2e8f0}.empty-state .empty-state-message{font-size:1rem;color:#64748b;margin-bottom:1.5rem}[data-theme=dark] .empty-state .empty-state-message{color:#94a3b8}.empty-state .empty-state-action{padding:.75rem 1.5rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.empty-state .empty-state-action:hover{background:#2563eb;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.spell-card-skeleton{background:linear-gradient(90deg, #f1f5f9 0%, #e2e8f0 50%, #f1f5f9 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg);height:280px}[data-theme=dark] .spell-card-skeleton{background:linear-gradient(90deg, #1e293b 0%, #334155 50%, #1e293b 100%)}@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.spell-card{animation:fadeInUp .4s ease-out backwards}.spell-card:nth-child(1){animation-delay:0.05s}.spell-card:nth-child(2){animation-delay:0.1s}.spell-card:nth-child(3){animation-delay:0.15s}.spell-card:nth-child(4){animation-delay:0.2s}.spell-card:nth-child(5){animation-delay:0.25s}.spell-card:nth-child(6){animation-delay:0.3s}.spell-card:nth-child(7){animation-delay:0.35s}.spell-card:nth-child(8){animation-delay:0.4s}.spell-card:nth-child(9){animation-delay:0.45s}.spell-card:nth-child(10){animation-delay:0.5s}.spell-card:nth-child(11){animation-delay:0.55s}.spell-card:nth-child(12){animation-delay:0.6s}.spell-card:nth-child(13){animation-delay:0.65s}.spell-card:nth-child(14){animation-delay:0.7s}.spell-card:nth-child(15){animation-delay:0.75s}.spell-card:nth-child(16){animation-delay:0.8s}.spell-card:nth-child(17){animation-delay:0.85s}.spell-card:nth-child(18){animation-delay:0.9s}.spell-card:nth-child(19){animation-delay:0.95s}.spell-card:nth-child(20){animation-delay:1s}.search-highlight{background:#fef08a;color:#713f12;padding:0 .25rem;border-radius:2px;font-weight:600}[data-theme=dark] .search-highlight{background:#854d0e;color:#fef08a}@media(max-width: 768px){.spellbook-container{overflow-x:hidden;max-width:100vw}.spellbook-toolbar{flex-direction:column;align-items:stretch;overflow-x:hidden}.spellbook-toolbar .toolbar-group{flex-direction:column;align-items:stretch}.spellbook-toolbar .toolbar-group select{width:100%;min-height:44px}.filter-section h3{font-size:.8125rem}.filter-chips{gap:.375rem}.filter-chip{font-size:.8125rem;padding:.375rem .625rem;min-height:44px}.spells-grid{max-width:100%;overflow-x:hidden}.spell-card{max-width:100%}}@media(hover: none)and (pointer: coarse){.filter-chip{min-height:44px;padding:.625rem 1rem;touch-action:manipulation}.spell-card{touch-action:manipulation;cursor:pointer}.spell-action-btn{min-height:44px;min-width:44px;padding:.75rem 1.25rem;touch-action:manipulation}.spell-action-btn.favorite-btn,.spell-action-btn.compare-btn{min-width:44px;min-height:44px}.spell-search-input{min-height:44px;font-size:16px;padding:.875rem 1rem .875rem 3rem;touch-action:manipulation}.toolbar-group select,.toolbar-group button{min-height:44px;font-size:16px;touch-action:manipulation}.clear-filters-btn{min-height:44px;padding:.75rem 1.25rem}.expand-description-btn{min-height:44px;padding:.625rem 1rem;touch-action:manipulation}.close-comparison-btn{min-height:44px;padding:.75rem 1.25rem;touch-action:manipulation}.spell-card,.filter-chip,.spell-action-btn{user-select:none;-webkit-user-select:none}}@media(max-width: 768px){.spell-comparison-container{max-height:80vh;padding:1rem}.spell-comparison-container.active{transform:translateY(0)}.comparison-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}.comparison-header{position:sticky;top:0;background:#fff;z-index:10;padding-bottom:1rem}[data-theme=dark] .comparison-header{background:#1e293b}.close-comparison-btn{min-width:44px;min-height:44px}}@media(max-width: 896px)and (orientation: landscape){.spellbook-container{padding:.5rem}.spell-filter-panel{padding:1rem;margin-bottom:1rem}.spells-grid{grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:1rem}.spell-card-header,.spell-card-body{padding:.75rem}.spell-stats-grid{gap:.5rem}}@media print{.spell-filter-panel,.spellbook-toolbar,.spell-card-actions,.spell-comparison-container{display:none !important}.spell-card{break-inside:avoid;page-break-inside:avoid;border:1px solid #000}.spells-grid{grid-template-columns:repeat(2, 1fr)}}:root{--spell-filter-primary: #6366f1;--spell-filter-primary-hover: #4f46e5;--spell-filter-secondary: #8b5cf6;--spell-filter-success: #10b981;--spell-filter-warning: #f59e0b;--spell-filter-danger: #ef4444;--spell-filter-bg: rgba(255, 255, 255, 0.95);--spell-filter-border: rgba(0, 0, 0, 0.1);--spell-filter-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);--spell-filter-shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.15);--spell-chip-bg: #f3f4f6;--spell-chip-hover: #e5e7eb;--spell-chip-active: #6366f1;--spell-chip-active-bg: rgba(99, 102, 241, 0.1);--transition-quick: 150ms ease;--transition-smooth: 250ms cubic-bezier(0.4, 0, 0.2, 1);--transition-bounce: 400ms cubic-bezier(0.68, -0.55, 0.265, 1.55)}[data-theme=dark]{--spell-filter-bg: rgba(30, 30, 40, 0.95);--spell-filter-border: rgba(255, 255, 255, 0.1);--spell-filter-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);--spell-chip-bg: #374151;--spell-chip-hover: #4b5563;--spell-chip-active-bg: rgba(99, 102, 241, 0.2)}.spell-filter-system{background:var(--spell-filter-bg);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:var(--spell-filter-shadow);border:1px solid var(--spell-filter-border);transition:box-shadow var(--transition-smooth)}@media(max-width: 768px){.spell-filter-system{padding:1.25rem;border-radius:12px}}.spell-filter-system:focus-within{box-shadow:var(--spell-filter-shadow-lg)}.spell-search-container{margin-bottom:2rem}@media(max-width: 768px){.spell-search-container{margin-bottom:1.5rem}}.search-input-wrapper{position:relative;max-width:600px;margin-bottom:1rem}@media(max-width: 768px){.search-input-wrapper{max-width:100%}}.search-input-wrapper .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none;transition:color var(--transition-quick)}.search-input-wrapper .spell-search-input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid var(--spell-filter-border);border-radius:12px;font-size:1rem;background:#fff;transition:all var(--transition-smooth)}[data-theme=dark] .search-input-wrapper .spell-search-input{background:#1f2937;color:#f9fafb}.search-input-wrapper .spell-search-input::placeholder{color:#9ca3af}.search-input-wrapper .spell-search-input:focus{outline:none;border-color:var(--spell-filter-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1)}.search-input-wrapper .spell-search-input:focus~.search-icon{color:var(--spell-filter-primary)}.search-input-wrapper .spell-search-input:hover:not(:focus){border-color:#d1d5db}.spell-results-count{font-size:.9375rem;color:#6b7280;font-weight:500;display:inline-flex;align-items:center;padding:.5rem 1rem;background:var(--spell-chip-bg);border-radius:8px;transition:all var(--transition-quick)}.spell-results-count.count-updated{animation:countPulse 300ms ease}@keyframes countPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05);color:var(--spell-filter-primary)}}.active-filters-container{display:none;flex-wrap:wrap;gap:.5rem;padding:1rem;background:rgba(99,102,241,.05);border-radius:12px;margin-bottom:1.5rem;border:1px dashed rgba(99,102,241,.2)}.active-filters-container:empty{display:none !important}.active-filters-container .active-filters-label{font-size:.875rem;font-weight:600;color:var(--spell-filter-primary);margin-right:.5rem;display:flex;align-items:center}.active-filter-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid var(--spell-filter-primary);border-radius:8px;font-size:.875rem;font-weight:500;color:var(--spell-filter-primary);box-shadow:0 2px 4px rgba(99,102,241,.1);animation:chipEnter var(--transition-bounce)}[data-theme=dark] .active-filter-chip{background:#1f2937}.active-filter-chip.chip-exit{animation:chipExit 200ms ease forwards}.active-filter-chip .remove-filter-btn{background:none;border:none;color:var(--spell-filter-primary);font-size:1.25rem;line-height:1;padding:0;cursor:pointer;transition:all var(--transition-quick);width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px}.active-filter-chip .remove-filter-btn:hover{background:rgba(99,102,241,.1);transform:scale(1.1)}.active-filter-chip .remove-filter-btn:active{transform:scale(0.95)}@keyframes chipEnter{0%{opacity:0;transform:scale(0.8) translateY(-10px)}60%{transform:scale(1.05) translateY(0)}100%{opacity:1;transform:scale(1) translateY(0)}}@keyframes chipExit{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(0.8)}}.filter-categories{display:flex;flex-direction:column;gap:2rem}@media(max-width: 768px){.filter-categories{gap:1.5rem}}.filter-category .filter-category-title{font-size:1rem;font-weight:600;color:#374151;margin-bottom:.875rem;display:flex;align-items:center;gap:.5rem}[data-theme=dark] .filter-category .filter-category-title{color:#f9fafb}.filter-category .filter-category-title::before{content:"";display:inline-block;width:4px;height:1rem;background:var(--spell-filter-primary);border-radius:2px}.filter-chips-grid{display:flex;flex-wrap:wrap;gap:.625rem}@media(max-width: 768px){.filter-chips-grid{gap:.5rem}}.filter-chip{display:inline-flex;align-items:center;gap:.375rem;padding:.625rem 1rem;background:var(--spell-chip-bg);border:2px solid rgba(0,0,0,0);border-radius:10px;font-size:.9375rem;font-weight:500;color:#374151;cursor:pointer;transition:all var(--transition-smooth);position:relative;overflow:hidden}[data-theme=dark] .filter-chip{color:#f9fafb}@media(max-width: 768px){.filter-chip{padding:.5rem .875rem;font-size:.875rem}}.filter-chip:hover:not(:disabled){background:var(--spell-chip-hover);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.filter-chip.active{background:var(--spell-chip-active-bg);border-color:var(--spell-filter-primary);color:var(--spell-filter-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1);transform:translateY(-1px)}.filter-chip.active::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--spell-filter-primary);animation:activeGlow 2s ease-in-out infinite}.filter-chip:focus{outline:none;box-shadow:0 0 0 3px rgba(99,102,241,.3)}.filter-chip.active:hover{background:rgba(99,102,241,.15);transform:translateY(-3px)}.filter-chip:active:not(:disabled){transform:translateY(0);transition:transform 50ms ease}.filter-chip .chip-icon{font-size:1.125rem;line-height:1;filter:grayscale(0.3);transition:filter var(--transition-quick)}.filter-chip.active .chip-icon,.filter-chip:hover .chip-icon{filter:grayscale(0)}@keyframes activeGlow{0%,100%{opacity:1}50%{opacity:.6}}.filter-chip.school-abjuration.active{border-color:#3b82f6;color:#3b82f6;background:rgba(59,130,246,.1)}.filter-chip.school-abjuration.active::before{background:#3b82f6}.filter-chip.school-conjuration.active{border-color:#8b5cf6;color:#8b5cf6;background:rgba(139,92,246,.1)}.filter-chip.school-conjuration.active::before{background:#8b5cf6}.filter-chip.school-divination.active{border-color:#06b6d4;color:#06b6d4;background:rgba(6,182,212,.1)}.filter-chip.school-divination.active::before{background:#06b6d4}.filter-chip.school-enchantment.active{border-color:#ec4899;color:#ec4899;background:rgba(236,72,153,.1)}.filter-chip.school-enchantment.active::before{background:#ec4899}.filter-chip.school-evocation.active{border-color:#f59e0b;color:#f59e0b;background:rgba(245,158,11,.1)}.filter-chip.school-evocation.active::before{background:#f59e0b}.filter-chip.school-illusion.active{border-color:#a855f7;color:#a855f7;background:rgba(168,85,247,.1)}.filter-chip.school-illusion.active::before{background:#a855f7}.filter-chip.school-necromancy.active{border-color:#6b7280;color:#6b7280;background:rgba(107,114,128,.1)}.filter-chip.school-necromancy.active::before{background:#6b7280}.filter-chip.school-transmutation.active{border-color:#10b981;color:#10b981;background:rgba(16,185,129,.1)}.filter-chip.school-transmutation.active::before{background:#10b981}.filter-actions{display:flex;justify-content:center;margin-top:1rem;padding-top:1.5rem;border-top:1px solid var(--spell-filter-border)}.clear-filters-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff;border:2px solid #e5e7eb;border-radius:10px;font-size:.9375rem;font-weight:600;color:#6b7280;cursor:pointer;transition:all var(--transition-smooth)}[data-theme=dark] .clear-filters-btn{background:#1f2937;border-color:#374151;color:#9ca3af}.clear-filters-btn svg{transition:transform var(--transition-quick)}.clear-filters-btn:hover:not(:disabled){background:#fef2f2;border-color:#fca5a5;color:#dc2626;transform:translateY(-2px);box-shadow:0 4px 12px rgba(220,38,38,.1)}[data-theme=dark] .clear-filters-btn:hover:not(:disabled){background:#450a0a;border-color:#991b1b}.clear-filters-btn:hover:not(:disabled) svg{transform:rotate(90deg)}.clear-filters-btn.has-filters{background:#fef2f2;border-color:#fca5a5;color:#dc2626;animation:buttonPulse 2s ease-in-out infinite}[data-theme=dark] .clear-filters-btn.has-filters{background:#450a0a;border-color:#991b1b}.clear-filters-btn.clearing{animation:clearingAnimation 600ms ease}.clear-filters-btn:disabled{opacity:.5;cursor:not-allowed}.clear-filters-btn:active:not(:disabled){transform:translateY(0)}.clear-filters-btn:focus{outline:none;box-shadow:0 0 0 3px rgba(220,38,38,.2)}@keyframes buttonPulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 8px rgba(220,38,38,0)}}@keyframes clearingAnimation{0%{transform:scale(1)}50%{transform:scale(0.95)}100%{transform:scale(1)}}.spell-row{transition:opacity var(--transition-smooth),transform var(--transition-smooth)}.spell-row:not([style*="display: none"]){animation:rowFadeIn 300ms ease}@keyframes rowFadeIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.badge[class*=badge-]{padding:.25rem .625rem;border-radius:6px;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge.badge-abjuration{background:rgba(59,130,246,.1);color:#2563eb;border:1px solid rgba(59,130,246,.2)}.badge.badge-conjuration{background:rgba(139,92,246,.1);color:#7c3aed;border:1px solid rgba(139,92,246,.2)}.badge.badge-divination{background:rgba(6,182,212,.1);color:#0891b2;border:1px solid rgba(6,182,212,.2)}.badge.badge-enchantment{background:rgba(236,72,153,.1);color:#db2777;border:1px solid rgba(236,72,153,.2)}.badge.badge-evocation{background:rgba(245,158,11,.1);color:#d97706;border:1px solid rgba(245,158,11,.2)}.badge.badge-illusion{background:rgba(168,85,247,.1);color:#9333ea;border:1px solid rgba(168,85,247,.2)}.badge.badge-necromancy{background:rgba(107,114,128,.1);color:#4b5563;border:1px solid rgba(107,114,128,.2)}.badge.badge-transmutation{background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.2)}.skip-to-results{position:absolute;left:-9999px}.skip-to-results:focus{position:fixed;top:1rem;left:1rem;z-index:9999;padding:1rem;background:var(--spell-filter-primary);color:#fff;border-radius:8px;text-decoration:none;box-shadow:0 4px 12px rgba(0,0,0,.3)}@media(prefers-contrast: high){.filter-chip{border-width:3px}.filter-chip.active{border-width:4px}.active-filter-chip{border-width:2px}}@media(prefers-reduced-motion: reduce){.filter-chip,.spell-row,.active-filter-chip,.clear-filters-btn{animation:none;transition:none}}.spell-filter-loading::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:hsla(0,0%,100%,.8);display:flex;align-items:center;justify-content:center;z-index:10;backdrop-filter:blur(2px)}@media(max-width: 640px){.spell-filter-system{padding:1rem}.filter-category-title{font-size:.9375rem}.filter-chip{padding:.5rem .75rem;font-size:.8125rem}.filter-chip .chip-icon{font-size:1rem}.active-filter-chip{font-size:.8125rem;padding:.375rem .625rem}.clear-filters-btn{width:100%;justify-content:center}}@media print{.spell-filter-system{display:none}}:root{--preset-primary: #6366f1;--preset-primary-hover: #4f46e5;--preset-success: #10b981;--preset-danger: #ef4444;--preset-warning: #f59e0b;--preset-info: #3b82f6;--preset-bg: #ffffff;--preset-bg-hover: #f9fafb;--preset-border: #e5e7eb;--preset-text: #374151;--preset-text-muted: #6b7280;--preset-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);--preset-shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.15)}[data-theme=dark]{--preset-bg: #1f2937;--preset-bg-hover: #374151;--preset-border: #4b5563;--preset-text: #f9fafb;--preset-text-muted: #9ca3af;--preset-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);--preset-shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.5)}.spell-preset-manager{margin-bottom:1.5rem}.preset-controls{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}@media(max-width: 640px){.preset-controls{flex-direction:column;width:100%}}.preset-dropdown-wrapper{position:relative}.preset-dropdown-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--preset-bg);border:2px solid var(--preset-border);border-radius:10px;font-size:.9375rem;font-weight:600;color:var(--preset-text);cursor:pointer;transition:all .2s ease}@media(max-width: 640px){.preset-dropdown-btn{width:100%;justify-content:center}}.preset-dropdown-btn:hover{background:var(--preset-bg-hover);border-color:var(--preset-primary);transform:translateY(-1px);box-shadow:var(--preset-shadow)}.preset-dropdown-btn:active{transform:translateY(0)}.preset-dropdown-btn .preset-icon{color:var(--preset-primary)}.preset-dropdown-btn .dropdown-arrow{transition:transform .2s ease}.preset-dropdown-wrapper:has(.preset-dropdown-menu.open) .preset-dropdown-btn .dropdown-arrow{transform:rotate(180deg)}.preset-dropdown-menu{display:none;position:absolute;top:calc(100% + .5rem);left:0;min-width:400px;max-width:500px;background:var(--preset-bg);border:1px solid var(--preset-border);border-radius:12px;box-shadow:var(--preset-shadow-lg);z-index:1000;max-height:600px;overflow:hidden;display:flex;flex-direction:column}@media(max-width: 640px){.preset-dropdown-menu{left:0;right:0;min-width:auto;max-width:100%;position:fixed;top:auto;bottom:0;border-radius:16px 16px 0 0;max-height:80vh}}.preset-dropdown-menu:not(.open){display:none}.preset-dropdown-menu.open{display:flex;animation:dropdownSlideIn .2s ease}@keyframes dropdownSlideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.preset-dropdown-header{padding:1rem 1.25rem;border-bottom:1px solid var(--preset-border);display:flex;justify-content:space-between;align-items:center}.preset-dropdown-header h4{margin:0;font-size:1rem;font-weight:700;color:var(--preset-text)}.preset-dropdown-header .preset-count{font-size:.875rem;color:var(--preset-text-muted);background:var(--preset-bg-hover);padding:.25rem .625rem;border-radius:12px;font-weight:600}.preset-list{flex:1;overflow-y:auto;padding:.5rem}.preset-list::-webkit-scrollbar{width:8px}.preset-list::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.preset-list::-webkit-scrollbar-thumb{background:var(--preset-border);border-radius:4px}.preset-list::-webkit-scrollbar-thumb:hover{background:var(--preset-text-muted)}.preset-section{margin-bottom:1rem}.preset-section:last-child{margin-bottom:0}.preset-section-title{font-size:.8125rem;font-weight:700;color:var(--preset-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:.5rem .75rem .25rem}.preset-empty-state{padding:3rem 2rem;text-align:center;color:var(--preset-text-muted);font-size:.9375rem}.preset-loading{padding:2rem;text-align:center;color:var(--preset-text-muted);font-size:.9375rem}.preset-item{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem;border-radius:8px;margin-bottom:.5rem;transition:all .2s ease;border:2px solid rgba(0,0,0,0)}.preset-item:hover{background:var(--preset-bg-hover);border-color:var(--preset-border)}.preset-item.active{background:rgba(99,102,241,.1);border-color:var(--preset-primary)}.preset-item.active .preset-name{color:var(--preset-primary)}.preset-item .preset-info{flex:1;cursor:pointer;min-width:0}.preset-item .preset-name{font-size:.9375rem;font-weight:600;color:var(--preset-text);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preset-item .preset-description{font-size:.8125rem;color:var(--preset-text-muted);line-height:1.4;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.preset-item .preset-meta{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.preset-item .preset-type-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.025em}.preset-item .preset-type-badge:contains("System"){background:rgba(59,130,246,.1);color:#3b82f6}.preset-item .preset-type-badge:contains("Custom"){background:rgba(16,185,129,.1);color:#10b981}.preset-item .preset-usage{font-size:.75rem;color:var(--preset-text-muted)}.preset-item .preset-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s ease}.preset-item:hover .preset-actions{opacity:1}.preset-action-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:rgba(0,0,0,0);border:none;border-radius:6px;color:var(--preset-text-muted);cursor:pointer;transition:all .15s ease}.preset-action-btn:hover{background:var(--preset-bg-hover);color:var(--preset-text);transform:scale(1.1)}.preset-action-btn:active{transform:scale(0.95)}.preset-action-btn.delete:hover{background:rgba(239,68,68,.1);color:var(--preset-danger)}.preset-action-btn svg{display:block}.preset-dropdown-footer{padding:.75rem 1.25rem;border-top:1px solid var(--preset-border);display:flex;gap:.5rem}.btn-import-preset{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--preset-bg-hover);border:1px solid var(--preset-border);border-radius:8px;font-size:.875rem;font-weight:600;color:var(--preset-text);cursor:pointer;transition:all .2s ease;flex:1;justify-content:center}.btn-import-preset:hover{background:var(--preset-bg);border-color:var(--preset-primary);color:var(--preset-primary)}.btn-save-preset{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--preset-primary);border:none;border-radius:10px;font-size:.9375rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease}@media(max-width: 640px){.btn-save-preset{width:100%;justify-content:center}}.btn-save-preset:hover{background:var(--preset-primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px rgba(99,102,241,.3)}.btn-save-preset:active{transform:translateY(0)}.btn-save-preset svg{flex-shrink:0}.preset-modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999}.preset-modal.show{display:block}.preset-modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);animation:fadeIn .2s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.preset-modal-content{position:relative;max-width:500px;width:90%;margin:10vh auto;background:var(--preset-bg);border-radius:16px;box-shadow:var(--preset-shadow-lg);z-index:10000;animation:modalSlideIn .3s ease}@media(max-width: 640px){.preset-modal-content{width:95%;margin:5vh auto}}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-20px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}.preset-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--preset-border)}.preset-modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--preset-text)}.preset-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:rgba(0,0,0,0);border:none;border-radius:8px;font-size:1.5rem;color:var(--preset-text-muted);cursor:pointer;transition:all .15s ease}.preset-modal-close:hover{background:var(--preset-bg-hover);color:var(--preset-text);transform:rotate(90deg)}.preset-modal-body{padding:1.5rem}.preset-modal-body .form-group{margin-bottom:1.25rem}.preset-modal-body .form-group:last-child{margin-bottom:0}.preset-modal-body label{display:block;font-size:.875rem;font-weight:600;color:var(--preset-text);margin-bottom:.5rem}.preset-modal-body .form-control{width:100%;padding:.75rem;border:2px solid var(--preset-border);border-radius:8px;font-size:.9375rem;color:var(--preset-text);background:var(--preset-bg);transition:all .2s ease}.preset-modal-body .form-control:focus{outline:none;border-color:var(--preset-primary);box-shadow:0 0 0 3px rgba(99,102,241,.1)}.preset-modal-body .form-control::placeholder{color:var(--preset-text-muted);opacity:.6}.preset-modal-body textarea.form-control{resize:vertical;min-height:80px}.preset-modal-body .form-text{display:block;margin-top:.375rem;font-size:.8125rem;color:var(--preset-text-muted)}.preset-modal-body .alert{display:flex;gap:.75rem;padding:.875rem 1rem;border-radius:8px;font-size:.875rem;line-height:1.5}.preset-modal-body .alert svg{flex-shrink:0;margin-top:.125rem}.preset-modal-body .alert.alert-info{background:rgba(59,130,246,.1);color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.preset-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid var(--preset-border)}.preset-modal-footer .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:8px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s ease}.preset-modal-footer .btn.btn-secondary{background:var(--preset-bg-hover);color:var(--preset-text);border:1px solid var(--preset-border)}.preset-modal-footer .btn.btn-secondary:hover{background:var(--preset-bg)}.preset-modal-footer .btn.btn-primary{background:var(--preset-primary);color:#fff}.preset-modal-footer .btn.btn-primary:hover{background:var(--preset-primary-hover);box-shadow:0 4px 12px rgba(99,102,241,.3)}.preset-modal-footer .btn:active{transform:translateY(1px)}.spell-preset-notification{position:fixed;top:20px;right:20px;min-width:280px;max-width:400px;padding:1rem 1.25rem;background:var(--preset-bg);border-radius:10px;box-shadow:var(--preset-shadow-lg);border-left:4px solid var(--preset-primary);z-index:10001;opacity:0;transform:translateX(400px);transition:all .3s cubic-bezier(0.68, -0.55, 0.265, 1.55);font-size:.9375rem;font-weight:500;color:var(--preset-text)}@media(max-width: 640px){.spell-preset-notification{top:auto;bottom:20px;left:20px;right:20px;min-width:auto;transform:translateY(200px)}}.spell-preset-notification.show{opacity:1;transform:translateX(0)}@media(max-width: 640px){.spell-preset-notification.show{transform:translateY(0)}}.spell-preset-notification.success{border-left-color:var(--preset-success)}.spell-preset-notification.error{border-left-color:var(--preset-danger)}.spell-preset-notification.warning{border-left-color:var(--preset-warning)}.spell-preset-notification.info{border-left-color:var(--preset-info)}@media(prefers-reduced-motion: reduce){*{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}@media(prefers-contrast: high){.preset-item{border-width:3px}.preset-action-btn:hover{border:2px solid currentColor}}.preset-dropdown-btn:focus-visible,.btn-save-preset:focus-visible,.btn-import-preset:focus-visible,.preset-action-btn:focus-visible,.preset-modal-close:focus-visible{outline:3px solid var(--preset-primary);outline-offset:2px}.preset-info:focus-visible{outline:2px solid var(--preset-primary);outline-offset:2px;border-radius:6px}@media print{.spell-preset-manager{display:none}}.error-modal{border:3px solid #dc2626;box-shadow:0 0 30px rgba(220,38,38,.4);border-radius:.5rem;overflow:hidden}.error-modal .modal-header{border-bottom:2px solid rgba(220,38,38,.2);padding:1.25rem 1.5rem}.error-modal .modal-header .modal-title{font-weight:600;font-size:1.25rem}.error-modal .modal-header .modal-title i{font-size:1.5rem;animation:shake .5s ease-in-out}.error-modal .modal-body{padding:1.5rem}.error-modal .modal-footer{padding:1rem 1.5rem;border-top:1px solid rgba(220,38,38,.1);background:rgba(220,38,38,.02)}.error-modal .modal-footer button{min-width:100px;font-weight:500;transition:all .2s ease}.error-modal .modal-footer button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.error-modal .modal-footer button:active:not(:disabled){transform:translateY(0)}.error-modal .modal-footer button:disabled{opacity:.6;cursor:not-allowed}.error-modal.error-critical{animation:error-pulse .5s ease-out;border-color:#dc2626;box-shadow:0 0 40px rgba(220,38,38,.6)}.error-modal.error-critical .modal-header{background:linear-gradient(135deg, #dc2626 0%, #991b1b 100%);border-bottom-color:#991b1b}.error-modal.error-critical .modal-body{background:linear-gradient(to bottom, rgba(220, 38, 38, 0.03) 0%, rgb(255, 255, 255) 50%)}.error-modal.error-critical .alert-warning{animation:pulse-warning 2s ease-in-out infinite}.error-message{font-size:1.125rem;color:#1f2937;margin-bottom:0;line-height:1.6;font-weight:500}.error-suggestions{background:rgba(220,38,38,.05);border-left:4px solid #dc2626;padding:1rem 1.25rem;border-radius:.375rem;margin-top:1rem}.error-suggestions strong{color:#991b1b;font-weight:600;display:block;margin-bottom:.5rem}.error-suggestions ul{margin-bottom:0;padding-left:1.25rem;list-style-type:none}.error-suggestions ul li{margin-bottom:.5rem;color:#4b5563;position:relative;padding-left:.5rem}.error-suggestions ul li:before{content:"→";position:absolute;left:-1rem;color:#dc2626;font-weight:bold}.error-suggestions ul li:last-child{margin-bottom:0}@keyframes error-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.02);box-shadow:0 0 40px rgba(220,38,38,.6)}}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px) rotate(-5deg)}75%{transform:translateX(5px) rotate(5deg)}}@keyframes pulse-warning{0%,100%{opacity:1}50%{opacity:.8}}.spinner-border-sm{width:1rem;height:1rem;border-width:.15em}@media(max-width: 576px){.error-modal .modal-body{padding:1rem}.error-modal .error-message{font-size:1rem}.error-modal .error-suggestions{padding:.75rem 1rem}.error-modal .error-suggestions ul li{font-size:.9rem}.error-modal .modal-footer{flex-direction:column;gap:.5rem}.error-modal .modal-footer button{width:100%;margin:0 !important}}[data-theme=dark] .error-modal{background:#1f2937;border-color:#ef4444}[data-theme=dark] .error-modal .modal-header{background:linear-gradient(135deg, #ef4444 0%, #b91c1c 100%);border-bottom-color:#991b1b;color:#fff}[data-theme=dark] .error-modal .modal-body{background:linear-gradient(to bottom, rgba(239, 68, 68, 0.05) 0%, #1f2937 50%)}[data-theme=dark] .error-modal .error-message{color:#f3f4f6}[data-theme=dark] .error-modal .error-suggestions{background:rgba(239,68,68,.1);border-left-color:#ef4444}[data-theme=dark] .error-modal .error-suggestions strong{color:#fca5a5}[data-theme=dark] .error-modal .error-suggestions li{color:#d1d5db}[data-theme=dark] .error-modal .error-suggestions li:before{color:#ef4444}[data-theme=dark] .error-modal .modal-footer{background:rgba(239,68,68,.03);border-top-color:rgba(239,68,68,.2)}[data-theme=dark] .error-modal.error-critical{box-shadow:0 0 50px rgba(239,68,68,.8)}[data-theme=dark] .error-modal.error-critical .modal-header{background:linear-gradient(135deg, #f87171 0%, #dc2626 100%)}[data-theme=dark] .error-modal.error-critical .alert-warning{background:rgba(251,146,60,.15);color:#fcd34d;border-color:rgba(251,146,60,.3)}[data-theme=dark] .alert.position-fixed{background:#1e293b;border-color:#334155;color:#f3f4f6;box-shadow:0 4px 12px rgba(0,0,0,.5)}[data-theme=dark] .alert.position-fixed .btn-close{filter:brightness(3) invert(0)}[data-theme=dark] .alert-danger.position-fixed{background:linear-gradient(135deg, #991b1b 0%, #7f1d1d 100%);border-color:#ef4444;color:#fef2f2}[data-theme=dark] .alert-warning.position-fixed{background:linear-gradient(135deg, #92400e 0%, #78350f 100%);border-color:#f59e0b;color:#fef3c7}[data-theme=dark] .alert-success.position-fixed{background:linear-gradient(135deg, #065f46 0%, #047857 100%);border-color:#10b981;color:#d1fae5}[data-theme=dark] .alert-info.position-fixed{background:linear-gradient(135deg, #1e40af 0%, #1e3a8a 100%);border-color:#3b82f6;color:#dbeafe}.error-modal button:focus-visible{outline:3px solid #3b82f6;outline-offset:2px}@media(prefers-contrast: high){.error-modal{border-width:4px}.error-modal .error-suggestions{border-left-width:6px}}@media(prefers-reduced-motion: reduce){.error-modal.error-critical{animation:none}.error-modal .modal-title i{animation:none}.error-modal .alert-warning{animation:none}.error-modal .modal-footer button:hover:not(:disabled){transform:none}}.alert.position-fixed{max-width:400px;z-index:9999;box-shadow:0 4px 12px rgba(0,0,0,.15);animation:slide-in-right .3s ease-out}.alert.position-fixed.fade:not(.show){animation:slide-out-right .3s ease-out}.alert.position-fixed .btn-close{filter:brightness(0) invert(1)}@keyframes slide-in-right{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slide-out-right{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}.modal-footer button i{margin-right:.25rem}@keyframes success-flash{0%,100%{background-color:rgba(0,0,0,0)}50%{background-color:rgba(34,197,94,.2)}}.retry-success{animation:success-flash .6s ease-out}.encounter-builder-wrapper{max-width:1200px;margin:0 auto}.wizard-progress{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.wizard-steps{display:flex;justify-content:space-between;position:relative}.wizard-steps::before{content:"";position:absolute;top:20px;left:10%;right:10%;height:2px;background:#e5e7eb;z-index:0}.wizard-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:1;flex:1}.step-number{width:40px;height:40px;border-radius:50%;background:#e5e7eb;color:#6b7280;display:flex;align-items:center;justify-content:center;font-weight:600;transition:all .3s ease}.wizard-step.active .step-number{background:linear-gradient(135deg, #dc2626 0%, #991b1b 100%);color:#fff;box-shadow:0 4px 12px rgba(220,38,38,.4);transform:scale(1.1)}.wizard-step.completed .step-number{background:#059669;color:#fff}.wizard-step.completed .step-number::before{content:"✓";font-weight:bold}.step-label{font-size:.875rem;font-weight:500;color:#6b7280;transition:color .3s ease}.wizard-step.active .step-label{color:#dc2626;font-weight:600}.wizard-step.completed .step-label{color:#059669}.wizard-step-content{display:none;animation:fadeIn .3s ease-in}.wizard-step-content.active{display:block}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.monster-item{transition:all .2s ease;cursor:pointer}.monster-item:hover{transform:translateX(4px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.monster-list::-webkit-scrollbar{width:8px}.monster-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.monster-list::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.monster-list::-webkit-scrollbar-thumb:hover{background:#555}.selected-monsters .card{transition:all .2s ease}.selected-monsters .card:hover{box-shadow:0 2px 8px rgba(0,0,0,.1)}.selected-monsters input[type=number]{text-align:center}.progress .progress-bar{transition:width .5s ease,background-color .3s ease;font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:center}.wizard-step:focus-visible{outline:2px solid #dc2626;outline-offset:4px;border-radius:4px}.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}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}@media print{.wizard-progress,.d-flex.justify-content-between.mt-4{display:none !important}.wizard-step-content{display:block !important;page-break-inside:avoid}}@media(max-width: 768px){.wizard-steps{gap:.5rem}.step-label{font-size:.75rem}.step-number{width:32px;height:32px;font-size:.875rem}.monster-list{max-height:300px !important}}@media(prefers-color-scheme: dark){.wizard-progress{background:#1f2937}.wizard-steps::before{background:#374151}.step-number{background:#374151;color:#9ca3af}.step-label{color:#9ca3af}.monster-list{background:#111827 !important}.card{background:#1f2937;color:#f3f4f6}}.quest-builder-wrapper{max-width:1200px;margin:0 auto}.quest-builder-wrapper .card-header{border-bottom:2px solid rgba(245,158,11,.3)}.quest-builder-wrapper [data-quest-builder-target=objectivesList] .card{transition:all .2s ease;border-left:3px solid rgba(0,0,0,0)}.quest-builder-wrapper [data-quest-builder-target=objectivesList] .card:hover{border-left-color:#f59e0b;box-shadow:0 2px 8px rgba(245,158,11,.15)}.quest-builder-wrapper [data-quest-builder-target=objectivesList] .input-group-text{background:linear-gradient(135deg, #f59e0b 0%, #d97706 100%);color:#fff;font-weight:600;border:none;min-width:45px;justify-content:center}.quest-builder-wrapper [data-quest-builder-target=objectivesList] .form-check-input:checked{background-color:#f59e0b;border-color:#f59e0b}.quest-builder-wrapper [data-quest-builder-target=objectivesList] input[type=number]{text-align:center;font-weight:600}.quest-builder-wrapper [data-quest-builder-target=rewardsList] .card{background:linear-gradient(to right, #fffbeb 0%, #fef3c7 100%);border:1px solid #fde68a;transition:all .2s ease}.quest-builder-wrapper [data-quest-builder-target=rewardsList] .card:hover{box-shadow:0 2px 8px rgba(245,158,11,.2);transform:translateX(2px)}.quest-builder-wrapper [data-quest-builder-target=rewardsList] select.form-select-sm{background-color:#fff;border-color:#f59e0b}[data-quest-builder-target=questTypeSelect]:focus{border-color:#f59e0b;box-shadow:0 0 0 .25rem rgba(245,158,11,.25)}button[data-action*=calculateRewards]:hover{background-color:#f59e0b;border-color:#f59e0b;color:#fff}button[data-action*=addObjective],button[data-action*=addReward]{position:relative;overflow:hidden}button[data-action*=addObjective]::before,button[data-action*=addReward]::before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.3);transform:translate(-50%, -50%);transition:width .6s,height .6s}button[data-action*=addObjective]:hover::before,button[data-action*=addReward]:hover::before{width:300px;height:300px}.quest-builder-wrapper .alert-info{background:linear-gradient(135deg, #e0f2fe 0%, #bae6fd 100%);border-left:4px solid #0284c7}.quest-builder-wrapper .alert-info .bi-lightbulb{color:#0284c7}.quest-builder-wrapper .text-muted.text-center i.bi{color:#d1d5db;margin-bottom:.5rem}#quest-giver-suggestions option{padding:.5rem;cursor:pointer}#quest-giver-suggestions option:hover{background-color:#fef3c7}.quest-builder-wrapper button:focus-visible{outline:2px solid #f59e0b;outline-offset:4px}.quest-builder-wrapper input:focus-visible,.quest-builder-wrapper select:focus-visible,.quest-builder-wrapper textarea:focus-visible{border-color:#f59e0b;box-shadow:0 0 0 .25rem rgba(245,158,11,.25)}@media(max-width: 768px){.quest-builder-wrapper .row.g-2>.col-auto{flex:0 0 auto;width:auto}.quest-builder-wrapper [data-quest-builder-target=objectivesList] .row.g-2{flex-wrap:wrap}.quest-builder-wrapper [data-quest-builder-target=rewardsList] .col-md-3,.quest-builder-wrapper [data-quest-builder-target=rewardsList] .col-md-7,.quest-builder-wrapper [data-quest-builder-target=rewardsList] .col-md-1{flex:0 0 100%;max-width:100%;margin-bottom:.5rem}}@media print{.quest-builder-wrapper button,.quest-builder-wrapper .btn,.quest-builder-wrapper .wizard-progress{display:none !important}.quest-builder-wrapper .wizard-step-content{display:block !important;page-break-inside:avoid}.quest-builder-wrapper .card{border:1px solid #000;page-break-inside:avoid}}@media(prefers-color-scheme: dark){.quest-builder-wrapper .card{background:#1f2937;color:#f3f4f6}.quest-builder-wrapper .card-header{border-bottom-color:rgba(245,158,11,.5)}.quest-builder-wrapper [data-quest-builder-target=rewardsList] .card{background:linear-gradient(to right, #374151 0%, #4b5563 100%);border-color:#f59e0b}.quest-builder-wrapper .input-group-text{color:#1f2937}.quest-builder-wrapper .alert-info{background:linear-gradient(135deg, #1e3a8a 0%, #1e40af 100%);color:#dbeafe;border-left-color:#3b82f6}}@keyframes slideInFromRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.quest-builder-wrapper [data-quest-builder-target=objectivesList] .card,.quest-builder-wrapper [data-quest-builder-target=rewardsList] .card{animation:slideInFromRight .3s ease-out}input[data-quest-builder-target=experienceReward],input[data-quest-builder-target=goldReward]{font-size:1.25rem;font-weight:600;text-align:center}input[data-quest-builder-target=experienceReward]:focus,input[data-quest-builder-target=goldReward]:focus{border-color:#f59e0b;box-shadow:0 0 0 .25rem rgba(245,158,11,.25)}.quest-builder-wrapper+.alert-success{animation:slideInFromTop .3s ease-out;box-shadow:0 4px 12px rgba(0,0,0,.15)}@keyframes slideInFromTop{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.location-form-wizard .wizard-progress .step-indicator{font-weight:500;color:#6c757d;transition:all .3s ease}.location-form-wizard .wizard-progress .step-indicator.active{color:#10b981;font-weight:600}.location-form-wizard .wizard-progress .step-indicator i{font-size:1.1rem;margin-right:.25rem}.location-form-wizard .wizard-progress .progress-bar{transition:width .4s ease;background:linear-gradient(90deg, #10b981 0%, #059669 100%)}.location-form-wizard .wizard-step{animation:fadeIn .3s ease}.location-form-wizard .wizard-step .card-header h5{display:flex;align-items:center}.location-form-wizard .wizard-step .card-header h5 i{font-size:1.3rem}.location-form-wizard .wizard-step .form-label i{font-size:1rem}.location-form-wizard .wizard-step .form-control,.location-form-wizard .wizard-step .form-select{border:2px solid #e5e7eb;transition:all .2s ease}.location-form-wizard .wizard-step .form-control:focus,.location-form-wizard .wizard-step .form-select:focus{border-color:#10b981;box-shadow:0 0 0 .2rem rgba(16,185,129,.15)}.location-form-wizard .wizard-step .form-control-lg{font-size:1.1rem;padding:.75rem 1rem}.location-form-wizard .poi-card{border:2px solid #e5e7eb;transition:all .2s ease;background:#fff}.location-form-wizard .poi-card:hover{border-color:#10b981;box-shadow:0 2px 8px rgba(16,185,129,.15);transform:translateY(-1px)}.location-form-wizard .poi-card .btn-outline-danger:hover{background:#ef4444;border-color:#ef4444;color:#fff}.location-form-wizard .establishment-card{border:2px solid #e5e7eb;transition:all .2s ease;background:#fff}.location-form-wizard .establishment-card:hover{border-color:#10b981;box-shadow:0 2px 8px rgba(16,185,129,.15);transform:translateY(-1px)}.location-form-wizard .establishment-card .btn-outline-danger:hover{background:#ef4444;border-color:#ef4444;color:#fff}.location-form-wizard .text-muted.text-center .bi{color:#d1d5db}.location-form-wizard .btn-lg{padding:.75rem 1.5rem;font-size:1.05rem;font-weight:500}.location-form-wizard .btn-primary{background:linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);border:none}.location-form-wizard .btn-primary:hover{background:linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);transform:translateY(-1px);box-shadow:0 4px 12px rgba(37,99,235,.3)}.location-form-wizard .btn-success{background:linear-gradient(135deg, #10b981 0%, #059669 100%);border:none}.location-form-wizard .btn-success:hover{background:linear-gradient(135deg, #059669 0%, #047857 100%);transform:translateY(-1px);box-shadow:0 4px 12px rgba(16,185,129,.3)}.location-form-wizard .btn-outline-secondary{border:2px solid #e5e7eb;color:#6b7280;font-weight:500}.location-form-wizard .btn-outline-secondary:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.location-form-wizard .alert-info{background:linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);color:#1e40af}.location-form-wizard .alert-info h6{color:#1e3a8a}.location-form-wizard .alert-info i{color:#3b82f6}.location-form-wizard .form-select option{padding:.5rem}.location-form-wizard input[type=number]::-webkit-inner-spin-button,.location-form-wizard input[type=number]::-webkit-outer-spin-button{opacity:1}.location-form-wizard .form-control-sm,.location-form-wizard .form-select-sm{font-size:.9rem;padding:.35rem .75rem}.location-form-wizard .form-label{margin-bottom:.35rem;font-weight:500}.location-form-wizard .form-label .text-success{color:#10b981 !important}.location-form-wizard .card{border-radius:12px;overflow:hidden}.location-form-wizard .card .card-header{border-bottom:none;padding:1.25rem 1.5rem}.location-form-wizard .card .card-body{padding:1.5rem}.location-form-wizard .form-text{font-size:.85rem;color:#6b7280;margin-top:.25rem}.location-form-wizard .alert{margin-bottom:0}.location-form-wizard .alert strong{font-weight:600}.location-form-wizard .alert i{font-size:1.1rem}@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width: 768px){.location-form-wizard .wizard-progress .step-indicator{font-size:.75rem}.location-form-wizard .wizard-progress .step-indicator i{display:block;margin:0 auto .25rem}.location-form-wizard .poi-card .row .col-md-1,.location-form-wizard .poi-card .row .col-md-2,.location-form-wizard .poi-card .row .col-md-3,.location-form-wizard .poi-card .row .col-md-4,.location-form-wizard .establishment-card .row .col-md-1,.location-form-wizard .establishment-card .row .col-md-2,.location-form-wizard .establishment-card .row .col-md-3,.location-form-wizard .establishment-card .row .col-md-4{margin-bottom:.5rem}}@media print{.location-form-wizard .wizard-progress,.location-form-wizard .btn,.location-form-wizard button{display:none !important}.location-form-wizard .wizard-step{display:block !important}}.inventory-container{background:linear-gradient(135deg, rgba(44, 62, 80, 0.95), rgba(52, 73, 94, 0.95));border:3px solid rgba(139,115,85,.6);border-radius:12px;padding:1.5rem;box-shadow:0 0 0 1px rgba(139,115,85,.3),inset 0 2px 10px rgba(0,0,0,.2),0 10px 40px rgba(0,0,0,.4);backdrop-filter:blur(10px)}.inventory-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid rgba(139,115,85,.3)}.inventory-title{margin-bottom:1.5rem}.inventory-title h2{color:#f5f5f5;font-size:1.75rem;font-weight:700;margin:0 0 .5rem 0;text-shadow:0 2px 4px rgba(0,0,0,.5);display:flex;align-items:center;gap:.75rem}.inventory-title .title-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3))}.inventory-subtitle{color:hsla(0,0%,100%,.7);font-size:.95rem;margin:0}.inventory-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem}.stat-card{background:linear-gradient(145deg, rgba(70, 70, 70, 0.7), rgba(50, 50, 50, 0.7));border:2px solid rgba(139,115,85,.4);border-radius:8px;padding:1rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease}.stat-card:hover{border-color:rgba(139,115,85,.6);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}.stat-card .stat-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3))}.stat-card .stat-info{flex:1}.stat-card .stat-label{color:hsla(0,0%,100%,.6);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.stat-card .stat-value{color:#f5f5f5;font-size:1.25rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3)}.weight-progress{width:100%;height:6px;background:rgba(0,0,0,.3);border-radius:3px;overflow:hidden;margin-top:.5rem;box-shadow:inset 0 1px 3px rgba(0,0,0,.3)}.weight-progress-bar{height:100%;transition:width .3s ease,background-color .3s ease;border-radius:3px}.weight-display.weight-light,.weight-progress-bar.bg-success{color:#4caf50;background:linear-gradient(90deg, #4caf50, #66bb6a);box-shadow:0 0 10px rgba(76,175,80,.4)}.weight-display.weight-moderate{color:#2196f3}.weight-display.weight-heavy,.weight-progress-bar.bg-warning{color:#ff9800;background:linear-gradient(90deg, #ff9800, #ffa726);box-shadow:0 0 10px rgba(255,152,0,.4);animation:weight-warning 2s ease-in-out infinite}.weight-display.weight-over-capacity,.weight-progress-bar.bg-danger{color:#f44336;background:linear-gradient(90deg, #f44336, #ef5350);box-shadow:0 0 15px rgba(244,67,54,.5);animation:weight-danger 1s ease-in-out infinite}.inventory-filters{background:rgba(0,0,0,.2);border:2px solid rgba(139,115,85,.3);border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.search-container{flex:1;min-width:250px;display:flex;gap:.5rem}.inventory-search{background:rgba(0,0,0,.3);border:2px solid rgba(139,115,85,.4);color:#f5f5f5;border-radius:6px;padding:.5rem 1rem;transition:all .3s ease}.inventory-search:focus{background:rgba(0,0,0,.4);border-color:#d4af37;box-shadow:0 0 15px rgba(212,175,55,.3);color:#f5f5f5}.inventory-search::placeholder{color:hsla(0,0%,100%,.4)}.filter-group{display:flex;gap:.5rem;flex-wrap:wrap}.filter-select{background:rgba(0,0,0,.3);border:2px solid rgba(139,115,85,.4);color:#f5f5f5;border-radius:6px;padding:.5rem 1rem;min-width:150px;transition:all .3s ease}.filter-select:focus{background:rgba(0,0,0,.4);border-color:#d4af37;box-shadow:0 0 15px rgba(212,175,55,.3);color:#f5f5f5}.filter-actions{display:flex;gap:.5rem}.inventory-groups{display:flex;flex-direction:column;gap:1rem}.inventory-group{background:rgba(0,0,0,.2);border:2px solid rgba(139,115,85,.3);border-radius:8px;overflow:hidden;transition:all .3s ease}.inventory-group:hover{border-color:rgba(139,115,85,.5)}.group-header{background:linear-gradient(145deg, rgba(70, 70, 70, 0.6), rgba(50, 50, 50, 0.6));padding:1rem 1.5rem;cursor:pointer;user-select:none;transition:all .3s ease;display:flex;align-items:center;justify-content:space-between}.group-header:hover{background:linear-gradient(145deg, rgba(90, 90, 90, 0.7), rgba(70, 70, 70, 0.7))}.group-header:active{transform:scale(0.98)}.group-title{display:flex;align-items:center;gap:.75rem;color:#f5f5f5;font-weight:600;font-size:1.1rem}.group-icon{transition:transform .3s ease;font-size:.8rem;color:hsla(0,0%,100%,.6)}.group-name{display:flex;align-items:center;gap:.5rem}.group-count{background:rgba(212,175,55,.2);border:1px solid rgba(212,175,55,.4);color:#d4af37;font-size:.8rem;padding:.25rem .75rem;border-radius:12px;font-weight:700}.group-items{overflow:hidden;transition:max-height .3s ease,opacity .3s ease}.items-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:1rem;padding:1rem}.inventory-item{background:linear-gradient(145deg, rgba(60, 60, 60, 0.9), rgba(40, 40, 40, 0.9));border:2px solid rgba(139,115,85,.4);border-radius:8px;padding:1rem;transition:all .3s ease;position:relative;overflow:hidden}.inventory-item::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg, transparent, rgba(212, 175, 55, 0.3), transparent);opacity:0;transition:opacity .3s ease}.inventory-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.4),0 0 25px rgba(212,175,55,.2);border-color:#d4af37;z-index:10}.inventory-item:hover::before{opacity:1}.inventory-item.item-equipped{background:linear-gradient(145deg, rgba(139, 115, 85, 0.4), rgba(115, 95, 70, 0.4));border-color:#d4af37;box-shadow:0 0 20px rgba(212,175,55,.4),inset 0 0 30px rgba(212,175,55,.1)}.inventory-item.item-equipped::before{opacity:1;background:linear-gradient(90deg, transparent, rgba(212, 175, 55, 0.6), transparent)}.item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;gap:1rem}.item-icon-container{position:relative;width:60px;height:60px;flex-shrink:0}.item-icon{font-size:3rem;text-align:center;filter:drop-shadow(0 2px 6px rgba(0, 0, 0, 0.5));animation:iconFloat 3s ease-in-out infinite}@keyframes iconFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}.quantity-badge{position:absolute;top:-4px;right:-4px;background:rgba(0,0,0,.8);color:#fff;border:2px solid rgba(212,175,55,.6);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;box-shadow:0 2px 6px rgba(0,0,0,.4)}.attuned-badge{position:absolute;bottom:-4px;left:-4px;background:linear-gradient(135deg, #9c27b0, #7b1fa2);color:#fff;border:2px solid rgba(156,39,176,.8);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;box-shadow:0 0 15px rgba(156,39,176,.6);animation:attunement-glow 2s ease-in-out infinite}.magic-indicator{position:absolute;top:-4px;left:-4px;font-size:1.25rem;filter:drop-shadow(0 0 8px rgba(138, 43, 226, 0.8));animation:magic-sparkle 2s ease-in-out infinite}@keyframes magic-sparkle{0%,100%{transform:scale(1) rotate(0deg);opacity:1}50%{transform:scale(1.1) rotate(10deg);opacity:.8}}.item-quick-action{flex:1;display:flex;justify-content:flex-end}.quick-action-btn{font-size:.875rem;font-weight:600;padding:.5rem 1rem;border-radius:6px;transition:all .3s ease;white-space:nowrap}.quick-action-btn .btn-icon{margin-right:.25rem}.quick-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}.quick-action-btn:active{transform:translateY(0)}.quick-action-btn.loading{pointer-events:none;opacity:.7}.item-body{margin-bottom:.75rem}.item-name-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.5rem}.item-name{color:#f5f5f5;font-size:1rem;font-weight:600;margin:0;text-shadow:0 1px 2px rgba(0,0,0,.3)}.item-rarity{font-size:.7rem;font-weight:700;text-transform:uppercase;padding:.25rem .5rem;border-radius:4px;letter-spacing:.5px;white-space:nowrap}.item-rarity.rarity-common{background:rgba(158,158,158,.2);color:#9e9e9e;border:1px solid rgba(158,158,158,.4)}.item-rarity.rarity-uncommon{background:rgba(76,175,80,.2);color:#4caf50;border:1px solid rgba(76,175,80,.4)}.item-rarity.rarity-rare{background:rgba(33,150,243,.2);color:#2196f3;border:1px solid rgba(33,150,243,.4)}.item-rarity.rarity-very-rare{background:rgba(156,39,176,.2);color:#9c27b0;border:1px solid rgba(156,39,176,.4)}.item-rarity.rarity-legendary{background:rgba(255,152,0,.2);color:#ff9800;border:1px solid rgba(255,152,0,.4);animation:legendary-pulse 2s ease-in-out infinite}.item-rarity.rarity-artifact{background:rgba(244,67,54,.2);color:#f44336;border:1px solid rgba(244,67,54,.4);animation:artifact-pulse 1.5s ease-in-out infinite}.item-description{color:hsla(0,0%,100%,.7);font-size:.85rem;line-height:1.4;margin-bottom:.75rem}.item-stats{display:flex;flex-wrap:wrap;gap:.75rem}.item-stat{display:flex;align-items:center;gap:.25rem;color:hsla(0,0%,100%,.6);font-size:.8rem}.item-stat .stat-icon{font-size:1rem}.equipped-badge{position:absolute;top:.5rem;right:.5rem;background:linear-gradient(135deg, rgba(212, 175, 55, 0.95), rgba(184, 145, 25, 0.95));color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;border:2px solid rgba(255,215,0,.6);box-shadow:0 2px 8px rgba(212,175,55,.5),inset 0 1px 2px hsla(0,0%,100%,.2);display:flex;align-items:center;gap:.25rem;text-transform:uppercase;letter-spacing:.5px;animation:fadeIn .3s ease}.equipped-badge .badge-icon{font-size:.875rem}.item-actions{position:absolute;bottom:.5rem;right:.5rem}.item-actions-dropdown{background:linear-gradient(135deg, #2c3e50, #34495e);border:2px solid rgba(139,115,85,.6);border-radius:6px;box-shadow:0 5px 20px rgba(0,0,0,.5);padding:.5rem 0;min-width:180px}.item-actions-dropdown .dropdown-item{color:#e0e0e0;padding:.5rem 1rem;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.item-actions-dropdown .dropdown-item:hover{background:rgba(212,175,55,.2);color:#fff}.item-actions-dropdown .dropdown-item.text-danger:hover{background:rgba(244,67,54,.2);color:#ff6b6b}.item-actions-dropdown .action-icon{font-size:1.1rem}.inventory-empty-state{text-align:center;padding:4rem 2rem;color:hsla(0,0%,100%,.6)}.inventory-empty-state .empty-icon{font-size:5rem;opacity:.3;margin-bottom:1rem;filter:drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3))}.inventory-empty-state h3{color:#f5f5f5;font-size:1.5rem;margin-bottom:.5rem}.inventory-empty-state p{color:hsla(0,0%,100%,.5);font-size:1rem}.inventory-toast{position:fixed;bottom:2rem;right:2rem;background:linear-gradient(135deg, #2c3e50, #34495e);border:2px solid rgba(139,115,85,.6);border-radius:8px;padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 5px 20px rgba(0,0,0,.5);opacity:0;transform:translateY(20px);transition:all .3s ease;z-index:10000}.inventory-toast.show{opacity:1;transform:translateY(0)}.inventory-toast .toast-icon{font-size:1.5rem;flex-shrink:0}.inventory-toast .toast-message{color:#f5f5f5;font-weight:600}.inventory-toast.toast-success{border-left:4px solid #4caf50}.inventory-toast.toast-danger{border-left:4px solid #f44336}.inventory-confirm-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10001;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.inventory-confirm-modal.show{opacity:1}.inventory-confirm-modal .modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);backdrop-filter:blur(5px)}.inventory-confirm-modal .modal-dialog{position:relative;z-index:1;max-width:400px;width:90%}.inventory-confirm-modal .modal-content{background:linear-gradient(135deg, #2c3e50, #34495e);border:3px solid rgba(139,115,85,.6);border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.5)}.inventory-confirm-modal .modal-header{border-bottom:2px solid rgba(139,115,85,.3);padding:1.5rem}.inventory-confirm-modal .modal-title{color:#f5f5f5;font-size:1.25rem;font-weight:700;margin:0}.inventory-confirm-modal .modal-body{padding:1.5rem;color:hsla(0,0%,100%,.8)}.inventory-confirm-modal .modal-footer{border-top:2px solid rgba(139,115,85,.3);padding:1rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end}@keyframes fadeIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}@keyframes fadeOut{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(0.9)}}@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}@keyframes legendary-pulse{0%,100%{box-shadow:0 0 10px rgba(255,152,0,.4)}50%{box-shadow:0 0 20px rgba(255,152,0,.7)}}@keyframes artifact-pulse{0%,100%{box-shadow:0 0 10px rgba(244,67,54,.4)}50%{box-shadow:0 0 20px rgba(244,67,54,.7)}}@keyframes attunement-glow{0%,100%{box-shadow:0 0 10px rgba(156,39,176,.5)}50%{box-shadow:0 0 20px rgba(156,39,176,.8)}}@keyframes weight-warning{0%,100%{opacity:1}50%{opacity:.85}}@keyframes weight-danger{0%,100%{opacity:1}50%{opacity:.8}}@media(max-width: 992px){.items-grid{grid-template-columns:repeat(auto-fill, minmax(250px, 1fr))}.inventory-filters{flex-direction:column;align-items:stretch}.search-container{width:100%}}@media(max-width: 768px){.inventory-container{padding:1rem}.items-grid{grid-template-columns:1fr;gap:.75rem}.inventory-stats{grid-template-columns:1fr}.item-header{flex-direction:column;align-items:flex-start}.item-quick-action{width:100%}.quick-action-btn{width:100%;justify-content:center}.inventory-toast{left:1rem;right:1rem;bottom:1rem}}@media(max-width: 576px){.inventory-title h2{font-size:1.5rem}.item-name-row{flex-direction:column;align-items:flex-start}.filter-group{flex-direction:column}.filter-select{width:100%}}.draggable-item{cursor:grab;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.draggable-item:active{cursor:grabbing}.inventory-item.dragging{opacity:.5;transform:scale(0.95);transition:opacity .2s ease,transform .2s ease;cursor:grabbing;z-index:1000}.inventory-item.keyboard-grabbed{outline:4px solid #d4af37;outline-offset:4px;box-shadow:0 0 0 4px rgba(212,175,55,.3),0 0 30px rgba(212,175,55,.5);animation:keyboard-grab-pulse 1.5s ease-in-out infinite}@keyframes keyboard-grab-pulse{0%,100%{box-shadow:0 0 0 4px rgba(212,175,55,.3),0 0 30px rgba(212,175,55,.5)}50%{box-shadow:0 0 0 6px rgba(212,175,55,.4),0 0 40px rgba(212,175,55,.7)}}.inventory-item.touch-dragging{opacity:.9;transform:scale(1.05) rotate(3deg);box-shadow:0 15px 40px rgba(0,0,0,.6),0 0 30px rgba(212,175,55,.4);transition:none;z-index:10000}.drag-ghost{opacity:.8;transform:rotate(3deg);box-shadow:0 10px 30px rgba(0,0,0,.5),0 0 20px rgba(212,175,55,.3)}.drop-zone{position:relative;transition:all .3s ease;min-height:100px}.drop-zone-ready{outline:3px dashed rgba(212,175,55,.4);outline-offset:8px;background:rgba(212,175,55,.05);transition:all .3s ease}.drop-zone-active{outline:3px solid rgba(212,175,55,.8);outline-offset:8px;background:linear-gradient(135deg, rgba(212, 175, 55, 0.15), rgba(184, 145, 25, 0.15));box-shadow:inset 0 0 30px rgba(212,175,55,.2),0 0 40px rgba(212,175,55,.3);animation:drop-zone-pulse 1s ease-in-out infinite}@keyframes drop-zone-pulse{0%,100%{background:linear-gradient(135deg, rgba(212, 175, 55, 0.15), rgba(184, 145, 25, 0.15))}50%{background:linear-gradient(135deg, rgba(212, 175, 55, 0.2), rgba(184, 145, 25, 0.2))}}.drop-indicator{position:absolute;left:0;right:0;height:4px;background:linear-gradient(90deg, transparent, #d4af37, transparent);box-shadow:0 0 10px rgba(212,175,55,.6),0 0 20px rgba(212,175,55,.4);border-radius:2px;pointer-events:none;z-index:1001;animation:drop-indicator-glow 1s ease-in-out infinite}.drop-indicator::before,.drop-indicator::after{content:"";position:absolute;top:50%;transform:translateY(-50%);width:12px;height:12px;background:#d4af37;border:2px solid hsla(0,0%,100%,.8);border-radius:50%;box-shadow:0 0 10px rgba(212,175,55,.8)}.drop-indicator::before{left:-6px}.drop-indicator::after{right:-6px}@keyframes drop-indicator-glow{0%,100%{opacity:1;box-shadow:0 0 10px rgba(212,175,55,.6),0 0 20px rgba(212,175,55,.4)}50%{opacity:.8;box-shadow:0 0 15px rgba(212,175,55,.8),0 0 30px rgba(212,175,55,.6)}}body.inventory-dragging{cursor:grabbing}body.inventory-dragging .inventory-item:not(.dragging){transition:transform .2s ease}body.inventory-dragging .inventory-item:not(.dragging):hover{transform:translateY(-2px)}.inventory-item.drag-over{transform:translateY(4px);transition:transform .2s ease}.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}.undo-button{position:fixed;bottom:80px;right:2rem;background:linear-gradient(135deg, #2c3e50, #34495e);border:2px solid rgba(139,115,85,.6);border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 20px rgba(0,0,0,.4),0 0 15px rgba(212,175,55,.2);cursor:pointer;transition:all .3s ease;z-index:9999;color:#d4af37;font-size:1.5rem}.undo-button:hover{transform:translateY(-3px) rotate(-5deg);box-shadow:0 8px 25px rgba(0,0,0,.5),0 0 25px rgba(212,175,55,.4);border-color:#d4af37}.undo-button:active{transform:translateY(-1px) rotate(-5deg)}.undo-button:disabled{opacity:.4;cursor:not-allowed;transform:none}@media(hover: none)and (pointer: coarse){.draggable-item{cursor:default}.inventory-item{touch-action:none;-webkit-touch-callout:none}.drop-zone-ready{outline-width:5px;outline-offset:12px}.drop-zone-active{outline-width:5px;outline-offset:12px}.inventory-item:active:not(.touch-dragging){background:rgba(212,175,55,.1);transition:background .1s ease}}.inventory-item:focus,.quick-action-btn:focus,.group-header:focus{outline:3px solid var(--bs-primary);outline-offset:2px}.inventory-item:focus-visible{outline:3px solid #d4af37;outline-offset:4px;box-shadow:0 0 20px rgba(212,175,55,.4)}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}.inventory-item.dragging{animation:none;transition:opacity .01ms}.drop-zone-active{animation:none}.drop-indicator{animation:none}}@media(prefers-contrast: high){.inventory-item,.stat-card,.inventory-group{border-width:3px}.drop-zone-ready,.drop-zone-active{outline-width:4px;outline-style:solid}.inventory-item.keyboard-grabbed{outline-width:6px}}.analytics-dashboard{width:100%;max-width:1400px;margin:0 auto;padding:2rem 1rem;background:#f9fafb;min-height:100vh}@media(min-width: 768px){.analytics-dashboard{padding:3rem 2rem}}.analytics-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}@media(min-width: 768px){.analytics-header{flex-direction:row;align-items:center;justify-content:space-between}}.analytics-header-content{flex:1}.analytics-title{margin:0 0 .5rem 0;font-size:1.875rem;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:.75rem}.analytics-title i{color:#6366f1}.analytics-subtitle{margin:0;font-size:1rem;color:#6b7280}.analytics-header-actions{display:flex;flex-direction:column;gap:1rem}@media(min-width: 640px){.analytics-header-actions{flex-direction:row;align-items:center}}.analytics-filter .form-select{min-width:180px;border-color:#e5e7eb;font-size:.875rem}.analytics-filter .form-select:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.1)}.analytics-export-buttons .btn{font-size:.875rem;padding:.5rem 1rem;border-color:#e5e7eb}.analytics-export-buttons .btn:hover{background-color:#6366f1;border-color:#6366f1;color:#fff}.analytics-export-buttons .btn i{margin-right:.25rem}.analytics-section{margin-bottom:2rem}.section-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1rem;padding-left:.5rem;border-left:4px solid #6366f1}.analytics-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1.5rem;margin-bottom:2rem}.analytics-metric-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);display:flex;align-items:center;gap:1.25rem;transition:transform .2s ease,box-shadow .2s ease}.analytics-metric-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05)}.metric-icon{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg, rgba(99, 102, 241, 0.1) 0%, rgba(99, 102, 241, 0.2) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0}.metric-icon i{font-size:1.75rem;color:#6366f1}.metric-content{flex:1;min-width:0}.metric-label{font-size:.875rem;font-weight:500;color:#6b7280;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:2rem;font-weight:700;color:#1f2937;line-height:1;margin-bottom:.5rem}.metric-trend{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:600;padding:.25rem .5rem;border-radius:6px}.metric-trend.metric-trend-success{color:#10b981;background:rgba(16,185,129,.1)}.metric-trend.metric-trend-danger{color:#ef4444;background:rgba(239,68,68,.1)}.metric-trend.metric-trend-secondary{color:#6b7280;background:rgba(107,114,128,.1)}.analytics-charts-container{display:grid;grid-template-columns:repeat(auto-fit, minmax(400px, 1fr));gap:2rem}@media(max-width: 640px){.analytics-charts-container{grid-template-columns:1fr}}.chart-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.chart-section.chart-section-wide{grid-column:1/-1}.chart-container{position:relative;height:350px;width:100%}.chart-container canvas{max-height:100%;width:100% !important;height:auto !important}.progression-heatmap{width:100%}.heatmap-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:1.5rem}.heatmap-grid{width:100%;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.heatmap-header{display:grid;grid-template-columns:2fr 1fr 2fr 1fr 1fr;gap:0;background:linear-gradient(135deg, #6366f1 0%, rgb(89.1, 91.8, 216.9) 100%);color:#fff;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.heatmap-header div{padding:1rem;border-right:1px solid hsla(0,0%,100%,.2)}.heatmap-header div:last-child{border-right:none}@media(max-width: 768px){.heatmap-header{grid-template-columns:1.5fr .5fr 1.5fr .8fr .7fr;font-size:.75rem}.heatmap-header div{padding:.75rem .5rem}}.heatmap-row{display:grid;grid-template-columns:2fr 1fr 2fr 1fr 1fr;gap:0;border-bottom:1px solid #e5e7eb}.heatmap-row:last-child{border-bottom:none}.heatmap-row:hover{background:rgba(99,102,241,.05)}@media(max-width: 768px){.heatmap-row{grid-template-columns:1.5fr .5fr 1.5fr .8fr .7fr}}.heatmap-cell{padding:1rem;display:flex;align-items:center;border-right:1px solid #e5e7eb;font-size:.875rem;color:#1f2937}.heatmap-cell:last-child{border-right:none}@media(max-width: 768px){.heatmap-cell{padding:.75rem .5rem;font-size:.75rem}}.level-badge{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:6px;font-weight:600;font-size:.875rem;min-width:40px}.level-badge.level-low{background:rgba(156,163,175,.2);color:#4b5563}.level-badge.level-mid{background:rgba(59,130,246,.2);color:#1e40af}.level-badge.level-high{background:rgba(139,92,246,.2);color:#6d28d9}.level-badge.level-epic{background:rgba(234,179,8,.2);color:#a16207}.progress-bar-container{position:relative;width:100%;height:24px;background:#f9fafb;border-radius:12px;overflow:hidden}.progress-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg, #6366f1 0%, rgb(114.6, 117.3, 242.4) 100%);border-radius:12px;transition:width .3s ease}.progress-text{position:relative;display:flex;align-items:center;justify-content:center;height:100%;font-size:.75rem;font-weight:600;color:#1f2937;z-index:1}.feat-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:rgba(245,158,11,.1);border-radius:6px;color:#d97706;font-weight:600;font-size:.875rem}.feat-badge i{font-size:.75rem}.analytics-footer{margin-top:3rem;padding:1.5rem;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.analytics-footer-text{margin:0;font-size:.875rem;color:#6b7280;display:flex;align-items:center;gap:.5rem}.analytics-footer-text i{color:#3b82f6}.analytics-dashboard button:focus,.analytics-dashboard select:focus,.analytics-dashboard a:focus{outline:2px solid #6366f1;outline-offset:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}@media(prefers-contrast: high){.analytics-metric-card,.chart-section{border:2px solid #1f2937}.metric-icon{border:1px solid #6366f1}}@media(prefers-reduced-motion: reduce){.analytics-metric-card,.progress-bar-fill{transition:none}}@media(prefers-color-scheme: dark){.analytics-dashboard{background:#1f2937}.analytics-metric-card,.chart-section,.analytics-header,.analytics-footer{background:#111827;color:#f9fafb}.analytics-title,.metric-value,.heatmap-cell{color:#f9fafb}.analytics-subtitle,.metric-label,.analytics-footer-text{color:#9ca3af}.heatmap-grid{border-color:#374151}.heatmap-row{border-color:#374151}.heatmap-row:hover{background:rgba(99,102,241,.15)}.heatmap-cell{border-color:#374151}.progress-bar-container{background:#374151}}@media(max-width: 640px){.analytics-dashboard{padding:1rem .5rem}.analytics-header{padding:1rem}.analytics-title{font-size:1.5rem}.analytics-metrics-grid{grid-template-columns:1fr}.chart-container{height:300px}.metric-value{font-size:1.5rem}}@media print{.analytics-dashboard{background:#fff;padding:0}.analytics-header-actions,.analytics-export-buttons{display:none}.analytics-metric-card,.chart-section{page-break-inside:avoid;box-shadow:none;border:1px solid #000}}.component-container{position:relative;width:100%}.animate{animation-duration:.5s;animation-fill-mode:both}.animate-delay-1{animation-delay:.1s}.animate-delay-2{animation-delay:.2s}.animate-delay-3{animation-delay:.3s}.glass-morphism{background:hsla(0,0%,100%,.1);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.2)}.neumorphism{background:#f0f0f0;box-shadow:20px 20px 60px #d1d1d1,-20px -20px 60px #fff}[data-theme=dark] .alert{background-color:var(--bg-secondary) !important;color:var(--text-primary) !important;border-color:var(--border-color) !important}[data-theme=dark] .alert-info{background:rgba(88, 166, 255, 0.15) !important;border-color:rgba(88, 166, 255, 0.3) !important;color:#c9d1d9 !important}[data-theme=dark] .alert-success{background:rgba(34, 197, 94, 0.15) !important;border-color:rgba(34, 197, 94, 0.3) !important;color:#d1fae5 !important}[data-theme=dark] .alert-warning{background:rgba(245, 158, 11, 0.15) !important;border-color:rgba(245, 158, 11, 0.3) !important;color:#fef3c7 !important}[data-theme=dark] .alert-danger{background:rgba(239, 68, 68, 0.15) !important;border-color:rgba(239, 68, 68, 0.3) !important;color:#fee2e2 !important}[data-theme=dark] .alert-heading{color:var(--text-primary) !important}[data-theme=dark] h1,[data-theme=dark] h2,[data-theme=dark] h3,[data-theme=dark] h4,[data-theme=dark] h5,[data-theme=dark] h6{color:var(--text-primary) !important}[data-theme=dark] p,[data-theme=dark] span,[data-theme=dark] div{color:inherit}[data-theme=dark] .text-muted,[data-theme=dark] .text-secondary{color:var(--text-secondary) !important}[data-theme=dark] .text-dark{color:var(--text-primary) !important}[data-theme=dark] .card,[data-theme=dark] .card-body,[data-theme=dark] .card-footer{background-color:var(--bg-secondary) !important;color:var(--text-primary) !important;border-color:var(--border-color) !important}[data-theme=dark] .card-header{background-color:rgba(255, 255, 255, 0.05) !important;border-bottom-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] table,[data-theme=dark] .table{color:var(--text-primary) !important;background-color:var(--bg-secondary) !important}[data-theme=dark] table th,[data-theme=dark] .table th{background-color:rgba(255, 255, 255, 0.05) !important;color:var(--text-secondary) !important;border-color:var(--border-color) !important}[data-theme=dark] table td,[data-theme=dark] .table td{border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] table tbody tr:hover,[data-theme=dark] .table tbody tr:hover{background-color:var(--bg-hover) !important}[data-theme=dark] .badge{background-color:rgba(255, 255, 255, 0.1) !important;color:var(--text-primary) !important}[data-theme=dark] .badge-primary{background:#1e3a8a !important;color:#93c5fd !important}[data-theme=dark] .badge-success{background:#064e3b !important;color:#6ee7b7 !important}[data-theme=dark] .badge-warning{background:#78350f !important;color:#fcd34d !important}[data-theme=dark] .badge-danger{background:#7f1d1d !important;color:#fca5a5 !important}[data-theme=dark] .badge-info{background:#1e40af !important;color:#93c5fd !important}[data-theme=dark] .character-sheet-container{background:var(--bg-primary) !important;color:var(--text-primary) !important}[data-theme=dark] .character-header{background:rgba(139, 92, 246, 0.1) !important;border-color:rgba(139, 92, 246, 0.3) !important;color:var(--text-primary) !important}[data-theme=dark] .character-name{color:var(--text-primary) !important}[data-theme=dark] .character-subtitle{color:var(--text-secondary) !important}[data-theme=dark] .stat-block,[data-theme=dark] .ability-score-box,[data-theme=dark] .skill-item{background-color:var(--bg-secondary) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .list-group-item{background-color:var(--bg-secondary) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .list-group-item:hover{background-color:var(--bg-hover) !important}[data-theme=dark] .list-group-item.active{background-color:var(--primary) !important;border-color:var(--primary) !important}[data-theme=dark] .well,[data-theme=dark] .panel{background-color:var(--bg-secondary) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .panel-heading{background-color:rgba(255, 255, 255, 0.05) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .input-group-text{background-color:var(--bg-hover) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .progress{background-color:rgba(255, 255, 255, 0.1) !important}[data-theme=dark] .nav-tabs{border-bottom-color:var(--border-color) !important}[data-theme=dark] .nav-tabs .nav-link{color:var(--text-secondary) !important;border-color:transparent !important}[data-theme=dark] .nav-tabs .nav-link:hover{border-color:var(--border-color) var(--border-color) var(--bg-primary) !important;color:var(--text-primary) !important}[data-theme=dark] .nav-tabs .nav-link.active{background-color:var(--bg-primary) !important;border-color:var(--border-color) var(--border-color) var(--bg-primary) !important;color:var(--text-primary) !important}[data-theme=dark] .nav-pills .nav-link{color:var(--text-secondary) !important}[data-theme=dark] .nav-pills .nav-link.active{background-color:var(--primary) !important;color:white !important}[data-theme=dark] .breadcrumb{background-color:var(--bg-secondary) !important}[data-theme=dark] .breadcrumb-item{color:var(--text-secondary) !important}[data-theme=dark] .breadcrumb-item.active{color:var(--text-primary) !important}[data-theme=dark] .breadcrumb-item+.breadcrumb-item::before{color:var(--text-muted) !important}[data-theme=dark] .pagination .page-link{background-color:var(--bg-secondary) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .pagination .page-link:hover{background-color:var(--bg-hover) !important;border-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .pagination .page-item.active .page-link{background-color:var(--primary) !important;border-color:var(--primary) !important}[data-theme=dark] .pagination .page-item.disabled .page-link{background-color:rgba(255, 255, 255, 0.05) !important;border-color:var(--border-color) !important;color:var(--text-muted) !important}[data-theme=dark] .tooltip .tooltip-inner{background-color:#1e293b !important;color:var(--text-primary) !important}[data-theme=dark] .popover{background-color:var(--bg-secondary) !important;border-color:var(--border-color) !important}[data-theme=dark] .popover-header{background-color:rgba(255, 255, 255, 0.05) !important;border-bottom-color:var(--border-color) !important;color:var(--text-primary) !important}[data-theme=dark] .popover-body{color:var(--text-primary) !important}[data-theme=dark] .spinner-border,[data-theme=dark] .spinner-grow{color:var(--primary) !important}[data-theme=dark] .jumbotron{background-color:var(--bg-secondary) !important;color:var(--text-primary) !important}[data-theme=dark] *[style*="background-color: #f8f9fa"],[data-theme=dark] *[style*="background-color: #e9ecef"],[data-theme=dark] *[style*="background-color: #dee2e6"],[data-theme=dark] *[style*="background-color: #ced4da"],[data-theme=dark] *[style*="background: white"],[data-theme=dark] *[style*="background-color: white"],[data-theme=dark] *[style*="background: #fff"],[data-theme=dark] *[style*="background-color: #fff"],[data-theme=dark] *[style*="background: #ffffff"],[data-theme=dark] *[style*="background-color: #ffffff"]{background-color:var(--bg-secondary) !important}[data-theme=dark] *[style*="color: #495057"],[data-theme=dark] *[style*="color: #6c757d"],[data-theme=dark] *[style*="color: black"],[data-theme=dark] *[style*="color: #000"],[data-theme=dark] *[style*="color: #000000"]{color:var(--text-primary) !important}[data-theme=dark] *[style*="border-color: #dee2e6"],[data-theme=dark] *[style*="border-color: #ced4da"],[data-theme=dark] *[style*="border-bottom: 2px solid #dee2e6"],[data-theme=dark] *[style*="border-top: 2px solid #dee2e6"]{border-color:var(--border-color) !important}[data-theme=dark]{color:var(--text-primary)}[data-theme=dark] *{border-color:var(--border-color)}[data-theme=dark] [style*="color: #333"],[data-theme=dark] [style*="color: #222"],[data-theme=dark] [style*="color: #111"]{color:var(--text-primary) !important}[data-theme=dark] .character-sheet h2{color:var(--dnd-gold) !important}[data-theme=dark] .character-sheet h3{color:var(--dnd-purple-light) !important}[data-theme=dark] .character-sheet h4{color:var(--text-primary) !important}[data-theme=dark] .section-header,[data-theme=dark] .stat-block-header{background:linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(236, 72, 153, 0.2) 100%) !important;border-color:rgba(139, 92, 246, 0.4) !important;color:var(--dnd-gold) !important}:root{--oracle-purple: #6a1b9a;--oracle-deep-purple: #4a148c;--oracle-mystical-blue: #1a237e;--oracle-arcane-cyan: #00bcd4;--oracle-glow: #e1bee7;--oracle-dark: #1a1a2e;--oracle-shimmer: #ffd700;--oracle-crystal: #e3f2fd}.ai-assistant-container{background:linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);border-radius:12px;position:relative;overflow:hidden}.ai-assistant-container::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 50%, rgba(106, 27, 154, 0.1) 0%, transparent 50%),radial-gradient(circle at 80% 80%, rgba(26, 35, 126, 0.1) 0%, transparent 50%);pointer-events:none;z-index:0}.oracle-header{background:linear-gradient(135deg, var(--oracle-purple) 0%, var(--oracle-deep-purple) 100%);border-radius:8px 8px 0 0;padding:1.5rem;position:relative;overflow:hidden;box-shadow:0 4px 20px rgba(106, 27, 154, 0.3)}.oracle-header::after{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);animation:oracle-shimmer 6s linear infinite;pointer-events:none}@keyframes oracle-shimmer{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.oracle-title{color:white;text-shadow:0 0 10px rgba(225, 190, 231, 0.5),0 0 20px rgba(225, 190, 231, 0.3);font-weight:600;margin:0;position:relative;z-index:1}.oracle-subtitle{color:var(--oracle-glow);font-size:.875rem;margin-top:.25rem;font-style:italic}.ai-oracle-icon{display:inline-block;animation:oracle-pulse 3s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(225, 190, 231, 0.6))}@keyframes oracle-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}.oracle-chat-container{background:rgba(255, 255, 255, 0.02);border-radius:8px;border:1px solid rgba(106, 27, 154, 0.3);backdrop-filter:blur(10px);position:relative}.oracle-chat-messages{background:linear-gradient(to bottom, rgba(26, 26, 46, 0.4), rgba(22, 33, 62, 0.4));border-radius:8px 8px 0 0;padding:1.5rem;max-height:550px;overflow-y:auto;position:relative}.oracle-chat-messages::-webkit-scrollbar{width:8px}.oracle-chat-messages::-webkit-scrollbar-track{background:rgba(26, 26, 46, 0.5);border-radius:4px}.oracle-chat-messages::-webkit-scrollbar-thumb{background:linear-gradient(to bottom, var(--oracle-purple), var(--oracle-deep-purple));border-radius:4px}.oracle-chat-messages::-webkit-scrollbar-thumb:hover{background:var(--oracle-purple)}.user-message .message-bubble{background:linear-gradient(135deg, #1976d2 0%, #1565c0 100%);color:white;box-shadow:0 4px 15px rgba(25, 118, 210, 0.3);border-radius:18px 18px 4px 18px;position:relative}.assistant-message .message-bubble{background:linear-gradient(135deg, rgba(106, 27, 154, 0.15) 0%, rgba(74, 20, 140, 0.15) 100%);border:1px solid rgba(106, 27, 154, 0.3);box-shadow:0 4px 15px rgba(106, 27, 154, 0.2),inset 0 0 20px rgba(225, 190, 231, 0.05);border-radius:18px 18px 18px 4px;position:relative;backdrop-filter:blur(10px)}.assistant-message .message-bubble::before{content:"";position:absolute;top:-1px;left:-1px;right:-1px;bottom:-1px;background:linear-gradient(135deg, rgba(225, 190, 231, 0.2), transparent);border-radius:inherit;opacity:0;transition:opacity .3s ease;pointer-events:none}.assistant-message .message-bubble:hover::before{opacity:1}.assistant-message .bi-robot{color:var(--oracle-arcane-cyan);filter:drop-shadow(0 0 4px rgba(0, 188, 212, 0.5))}.oracle-loading{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg, rgba(106, 27, 154, 0.1) 0%, rgba(74, 20, 140, 0.1) 100%);border:1px solid rgba(106, 27, 154, 0.3);border-radius:18px;box-shadow:0 4px 15px rgba(106, 27, 154, 0.15)}.oracle-thinking-text{color:var(--oracle-glow);font-style:italic;animation:thinking-fade 2s ease-in-out infinite}@keyframes thinking-fade{0%,100%{opacity:.6}50%{opacity:1}}.oracle-spinner{position:relative;width:24px;height:24px}.oracle-spinner::before,.oracle-spinner::after{content:"";position:absolute;border-radius:50%;border:2px solid transparent;border-top-color:var(--oracle-arcane-cyan);border-right-color:var(--oracle-purple);animation:oracle-spin 1.5s linear infinite}.oracle-spinner::before{top:0;left:0;right:0;bottom:0}.oracle-spinner::after{top:3px;left:3px;right:3px;bottom:3px;border-top-color:var(--oracle-shimmer);border-right-color:var(--oracle-glow);animation-direction:reverse;animation-duration:2s}@keyframes oracle-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.oracle-input-container{background:rgba(26, 26, 46, 0.6);border-top:1px solid rgba(106, 27, 154, 0.3);padding:1rem;border-radius:0 0 8px 8px}.oracle-input{background:rgba(255, 255, 255, 0.05);border:1px solid rgba(106, 27, 154, 0.4);color:#fff;border-radius:8px;padding:.75rem;transition:all .3s ease}.oracle-input:focus{background:rgba(255, 255, 255, 0.08);border-color:var(--oracle-arcane-cyan);box-shadow:0 0 15px rgba(0, 188, 212, 0.3),inset 0 0 10px rgba(106, 27, 154, 0.2);outline:none}.oracle-input::placeholder{color:rgba(225, 190, 231, 0.5);font-style:italic}.oracle-quick-action{background:linear-gradient(135deg, rgba(106, 27, 154, 0.2) 0%, rgba(74, 20, 140, 0.2) 100%);border:1px solid rgba(106, 27, 154, 0.4);color:var(--oracle-glow);padding:.5rem 1rem;border-radius:20px;transition:all .3s ease;font-size:.875rem;position:relative;overflow:hidden}.oracle-quick-action::before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:radial-gradient(circle, rgba(225, 190, 231, 0.3), transparent);transform:translate(-50%, -50%);transition:width .4s ease,height .4s ease}.oracle-quick-action:hover{background:linear-gradient(135deg, rgba(106, 27, 154, 0.4) 0%, rgba(74, 20, 140, 0.4) 100%);border-color:var(--oracle-arcane-cyan);color:white;box-shadow:0 0 15px rgba(0, 188, 212, 0.4);transform:translateY(-2px)}.oracle-quick-action:hover::before{width:200px;height:200px}.oracle-tool-card{background:linear-gradient(135deg, rgba(106, 27, 154, 0.1) 0%, rgba(74, 20, 140, 0.1) 100%);border:1px solid rgba(106, 27, 154, 0.3);border-radius:8px;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.oracle-tool-card::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg, transparent, rgba(225, 190, 231, 0.2), transparent);transition:left .5s ease}.oracle-tool-card:hover{background:linear-gradient(135deg, rgba(106, 27, 154, 0.2) 0%, rgba(74, 20, 140, 0.2) 100%);border-color:var(--oracle-arcane-cyan);box-shadow:0 4px 20px rgba(106, 27, 154, 0.4),inset 0 0 15px rgba(225, 190, 231, 0.1);transform:translateY(-2px)}.oracle-tool-card:hover::before{left:100%}.oracle-tool-card i{color:var(--oracle-arcane-cyan);filter:drop-shadow(0 0 4px rgba(0, 188, 212, 0.5));transition:all .3s ease}.oracle-tool-card:hover i{transform:scale(1.1);filter:drop-shadow(0 0 8px rgba(0, 188, 212, 0.8))}.oracle-token-bar-container{background:rgba(26, 26, 46, 0.6);border-radius:8px;padding:1rem;border:1px solid rgba(106, 27, 154, 0.3)}.oracle-token-bar{height:28px;background:linear-gradient(to right, var(--oracle-purple), var(--oracle-arcane-cyan));border-radius:14px;position:relative;overflow:hidden;box-shadow:0 0 15px rgba(106, 27, 154, 0.5),inset 0 2px 4px rgba(0, 0, 0, 0.3)}.oracle-token-bar::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);animation:token-shimmer 3s linear infinite}@keyframes token-shimmer{0%{left:-100%}100%{left:100%}}.oracle-personality-card{background:linear-gradient(135deg, rgba(106, 27, 154, 0.15) 0%, rgba(74, 20, 140, 0.15) 100%);border:1px solid rgba(106, 27, 154, 0.3);border-radius:8px;padding:1rem}.oracle-personality-badge{display:inline-block;padding:.25rem .75rem;background:linear-gradient(135deg, var(--oracle-purple), var(--oracle-deep-purple));color:white;border-radius:12px;font-size:.75rem;box-shadow:0 2px 8px rgba(106, 27, 154, 0.4);margin-right:.5rem;margin-bottom:.5rem}.oracle-modal .modal-content{background:linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);border:1px solid rgba(106, 27, 154, 0.5);box-shadow:0 10px 40px rgba(106, 27, 154, 0.3)}.oracle-modal .modal-header{background:linear-gradient(135deg, var(--oracle-purple) 0%, var(--oracle-deep-purple) 100%);border-bottom:1px solid rgba(106, 27, 154, 0.5);position:relative;overflow:hidden}.oracle-modal .modal-header::after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);animation:modal-shimmer 4s ease-in-out infinite}@keyframes modal-shimmer{0%,100%{left:-100%}50%{left:100%}}.oracle-modal .modal-title{color:white;text-shadow:0 0 10px rgba(225, 190, 231, 0.5);position:relative;z-index:1}.oracle-modal .modal-body{color:#e0e0e0}.oracle-modal .form-control,.oracle-modal .form-select{background:rgba(255, 255, 255, 0.05);border:1px solid rgba(106, 27, 154, 0.4);color:#fff}.oracle-modal .form-control:focus,.oracle-modal .form-select:focus{background:rgba(255, 255, 255, 0.08);border-color:var(--oracle-arcane-cyan);box-shadow:0 0 10px rgba(0, 188, 212, 0.3);color:#fff}.oracle-suggestion-card{background:linear-gradient(135deg, rgba(106, 27, 154, 0.1) 0%, rgba(74, 20, 140, 0.1) 100%);border:1px solid rgba(106, 27, 154, 0.3);border-left:4px solid var(--oracle-arcane-cyan);border-radius:4px;padding:1rem;margin-bottom:.75rem;transition:all .3s ease}.oracle-suggestion-card:hover{background:linear-gradient(135deg, rgba(106, 27, 154, 0.2) 0%, rgba(74, 20, 140, 0.2) 100%);box-shadow:0 4px 15px rgba(106, 27, 154, 0.3);transform:translateX(4px)}.oracle-priority-badge{background:linear-gradient(135deg, var(--oracle-purple), var(--oracle-deep-purple));color:white;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:.875rem;box-shadow:0 2px 8px rgba(106, 27, 154, 0.4);flex-shrink:0}.oracle-screen-reader-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}.oracle-quick-action:focus,.oracle-tool-card:focus{outline:2px solid var(--oracle-arcane-cyan);outline-offset:2px}.oracle-empty-state{text-align:center;padding:3rem 1.5rem;color:rgba(225, 190, 231, 0.6)}.oracle-empty-state i{font-size:4rem;color:var(--oracle-purple);opacity:.3;animation:float 3s ease-in-out infinite}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}.oracle-success-glow{animation:success-pulse 1s ease-out}@keyframes success-pulse{0%{box-shadow:0 0 0 0 rgba(0, 188, 212, 0.7)}50%{box-shadow:0 0 20px 10px rgba(0, 188, 212, 0.3)}100%{box-shadow:0 0 0 0 rgba(0, 188, 212, 0)}}.oracle-copy-btn{background:linear-gradient(135deg, rgba(106, 27, 154, 0.3) 0%, rgba(74, 20, 140, 0.3) 100%);border:1px solid rgba(106, 27, 154, 0.5);color:var(--oracle-glow);transition:all .3s ease}.oracle-copy-btn:hover{background:linear-gradient(135deg, var(--oracle-purple) 0%, var(--oracle-deep-purple) 100%);border-color:var(--oracle-arcane-cyan);color:white;box-shadow:0 0 15px rgba(0, 188, 212, 0.5)}.oracle-copy-btn.copied{background:linear-gradient(135deg, #388e3c 0%, #2e7d32 100%);border-color:#4caf50;color:white}@media(max-width: 768px){.oracle-chat-messages{max-height:400px}.oracle-header{padding:1rem}.oracle-title{font-size:1.25rem}.message-bubble{max-width:90% !important}}@media print{.oracle-chat-container,.oracle-modal{background:white;color:black}.message-bubble{box-shadow:none;border:1px solid #ddd}}:root{--auth-bg-gradient-start: #667eea;--auth-bg-gradient-end: #764ba2;--auth-card-bg: rgba(255, 255, 255, 0.95);--auth-card-border: rgba(255, 255, 255, 0.18);--auth-text-primary: #1a202c;--auth-text-secondary: #718096;--auth-input-bg: #ffffff;--auth-input-border: #e2e8f0;--auth-input-focus: #667eea;--auth-shadow: rgba(0, 0, 0, 0.1);--auth-shadow-hover: rgba(0, 0, 0, 0.15);--auth-primary: #667eea;--auth-primary-hover: #5a67d8;--auth-success: #48bb78;--auth-error: #f56565;--auth-warning: #ed8936;--discord-color: #5865F2;--discord-hover: #4752c4;--github-color: #24292e;--github-hover: #1a1e21;--google-color: #ffffff;--google-hover: #f7f7f7;--google-border: #dadce0;--google-text: #3c4043;--auth-spacing-xs: 0.5rem;--auth-spacing-sm: 1rem;--auth-spacing-md: 1.5rem;--auth-spacing-lg: 2rem;--auth-spacing-xl: 3rem;--auth-radius-sm: 0.375rem;--auth-radius-md: 0.5rem;--auth-radius-lg: 1rem;--auth-radius-full: 9999px;--auth-transition-fast: 150ms ease;--auth-transition-base: 200ms ease;--auth-transition-slow: 300ms ease}@media(prefers-color-scheme: dark){:root{--auth-bg-gradient-start: #1a202c;--auth-bg-gradient-end: #2d3748;--auth-card-bg: rgba(45, 55, 72, 0.95);--auth-card-border: rgba(255, 255, 255, 0.1);--auth-text-primary: #f7fafc;--auth-text-secondary: #a0aec0;--auth-input-bg: #2d3748;--auth-input-border: #4a5568;--auth-shadow: rgba(0, 0, 0, 0.3);--auth-shadow-hover: rgba(0, 0, 0, 0.4)}}[data-theme=dark]{--auth-bg-gradient-start: #1a202c;--auth-bg-gradient-end: #2d3748;--auth-card-bg: rgba(45, 55, 72, 0.95);--auth-card-border: rgba(255, 255, 255, 0.1);--auth-text-primary: #f7fafc;--auth-text-secondary: #a0aec0;--auth-input-bg: #2d3748;--auth-input-border: #4a5568;--auth-shadow: rgba(0, 0, 0, 0.3);--auth-shadow-hover: rgba(0, 0, 0, 0.4)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--auth-spacing-md);background:linear-gradient(135deg, var(--auth-bg-gradient-start) 0%, var(--auth-bg-gradient-end) 100%);background-size:200% 200%;animation:gradientShift 15s ease infinite;position:relative;overflow:hidden}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}.auth-page::before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle, rgba(255, 255, 255, 0.1) 1px, transparent 1px);background-size:50px 50px;animation:particleFloat 20s linear infinite;pointer-events:none}@keyframes particleFloat{from{transform:translate(0, 0)}to{transform:translate(50px, 50px)}}.auth-card{width:100%;max-width:460px;background:var(--auth-card-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--auth-radius-lg);border:1px solid var(--auth-card-border);box-shadow:0 8px 32px 0 var(--auth-shadow),0 2px 8px 0 rgba(0, 0, 0, 0.05);padding:var(--auth-spacing-xl);position:relative;z-index:1;animation:cardFadeIn .6s ease}@keyframes cardFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-card:hover{box-shadow:0 12px 40px 0 var(--auth-shadow-hover),0 2px 8px 0 rgba(0, 0, 0, 0.05);transition:box-shadow var(--auth-transition-base)}.auth-card h1{font-size:2rem;font-weight:700;color:var(--auth-text-primary);margin:0 0 var(--auth-spacing-xs) 0;text-align:center}.auth-card .auth-subtitle{font-size:.95rem;color:var(--auth-text-secondary);text-align:center;margin-bottom:var(--auth-spacing-lg)}.auth-card .social-proof{text-align:center;font-size:.875rem;color:var(--auth-text-secondary);margin-bottom:var(--auth-spacing-lg);display:flex;align-items:center;justify-content:center;gap:var(--auth-spacing-xs)}.auth-card .social-proof svg{width:16px;height:16px;color:var(--auth-success)}.auth-form{display:flex;flex-direction:column;gap:var(--auth-spacing-md)}.form-group{position:relative;display:flex;flex-direction:column;gap:var(--auth-spacing-xs)}.form-group label{font-size:.875rem;font-weight:500;color:var(--auth-text-primary);display:flex;align-items:center;gap:var(--auth-spacing-xs)}.form-group label .required{color:var(--auth-error)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;width:20px !important;height:20px !important;color:var(--auth-text-secondary);pointer-events:none;transition:color var(--auth-transition-fast)}.form-control{width:100%;padding:.875rem 1rem;padding-left:3rem;font-size:1rem;color:var(--auth-text-primary);background:var(--auth-input-bg);border:2px solid var(--auth-input-border);border-radius:var(--auth-radius-md);transition:all var(--auth-transition-fast);outline:none}.form-control:focus{border-color:var(--auth-input-focus);box-shadow:0 0 0 3px rgba(102, 126, 234, 0.1)}.form-control:focus+.input-icon{color:var(--auth-input-focus)}.form-control.error{border-color:var(--auth-error);animation:shake .4s ease}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.form-control.success{border-color:var(--auth-success)}.password-toggle{position:absolute;right:1rem;background:none;border:none;color:var(--auth-text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color var(--auth-transition-fast)}.password-toggle:hover{color:var(--auth-text-primary)}.password-toggle svg{width:20px !important;height:20px !important}.password-strength{margin-top:var(--auth-spacing-xs)}.password-strength-bar{height:4px;background:var(--auth-input-border);border-radius:var(--auth-radius-full);overflow:hidden;margin-bottom:var(--auth-spacing-xs)}.password-strength-progress{height:100%;width:0%;transition:all var(--auth-transition-base);border-radius:var(--auth-radius-full)}.password-strength-progress.weak{width:25%;background:var(--auth-error)}.password-strength-progress.fair{width:50%;background:var(--auth-warning)}.password-strength-progress.good{width:75%;background:#48bb78}.password-strength-progress.strong{width:100%;background:var(--auth-success)}.password-requirements{font-size:.8rem;color:var(--auth-text-secondary);list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:var(--auth-spacing-xs)}.password-requirements li{display:flex;align-items:center;gap:.375rem;transition:color var(--auth-transition-fast)}.password-requirements li svg{width:14px !important;height:14px !important}.password-requirements li.met{color:var(--auth-success)}.field-error{font-size:.8rem;color:var(--auth-error);display:flex;align-items:center;gap:.375rem;margin-top:.25rem}.field-error svg{width:14px;height:14px}.field-success{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--auth-success);animation:checkmarkPop .3s ease}@keyframes checkmarkPop{0%{transform:translateY(-50%) scale(0)}50%{transform:translateY(-50%) scale(1.2)}100%{transform:translateY(-50%) scale(1)}}.field-success svg{width:20px;height:20px}.checkbox-group{display:flex;align-items:center;gap:var(--auth-spacing-xs)}.checkbox-group input[type=checkbox]{width:18px;height:18px;accent-color:var(--auth-primary);cursor:pointer}.checkbox-group label{font-size:.875rem;color:var(--auth-text-secondary);cursor:pointer;margin:0}.btn{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border-radius:var(--auth-radius-md);border:none;cursor:pointer;transition:all var(--auth-transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--auth-spacing-xs);text-decoration:none;position:relative;overflow:hidden}.btn-primary{background:var(--auth-primary);color:white;box-shadow:0 4px 12px rgba(102, 126, 234, 0.3)}.btn-primary:hover{background:var(--auth-primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px rgba(102, 126, 234, 0.4)}.btn-primary:active{transform:translateY(0)}.btn.loading{pointer-events:none;opacity:.7}.btn.loading::after{content:"";position:absolute;width:16px;height:16px;border:2px solid rgba(255, 255, 255, 0.3);border-top-color:white;border-radius:50%;animation:btnSpin .6s linear infinite}@keyframes btnSpin{to{transform:rotate(360deg)}}.btn.loading .btn-text{opacity:0}.oauth-section{margin-top:var(--auth-spacing-lg)}.divider{display:flex;align-items:center;text-align:center;margin:var(--auth-spacing-lg) 0;color:var(--auth-text-secondary);font-size:.875rem}.divider::before,.divider::after{content:"";flex:1;border-bottom:1px solid var(--auth-input-border)}.divider span{padding:0 var(--auth-spacing-sm)}.oauth-buttons{display:flex;flex-direction:column;gap:var(--auth-spacing-sm)}.btn-oauth{width:100%;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;border-radius:var(--auth-radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--auth-transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--auth-spacing-sm);text-decoration:none;position:relative}.btn-oauth:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--auth-shadow)}.btn-oauth svg{width:20px;height:20px}.btn-discord{background:var(--discord-color);color:white}.btn-discord:hover{background:var(--discord-hover)}.btn-github{background:var(--github-color);color:white}.btn-github:hover{background:var(--github-hover)}.btn-google{background:var(--google-color);color:var(--google-text);border-color:var(--google-border)}.btn-google:hover{background:var(--google-hover)}.auth-link{color:var(--auth-primary);text-decoration:none;font-size:.875rem;font-weight:500;transition:color var(--auth-transition-fast)}.auth-link:hover{color:var(--auth-primary-hover);text-decoration:underline}.form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:var(--auth-spacing-sm)}.auth-footer{margin-top:var(--auth-spacing-lg);padding-top:var(--auth-spacing-lg);border-top:1px solid var(--auth-input-border);text-align:center;font-size:.875rem;color:var(--auth-text-secondary)}.auth-footer a{color:var(--auth-primary);text-decoration:none;font-weight:600;transition:color var(--auth-transition-fast)}.auth-footer a:hover{color:var(--auth-primary-hover)}.auth-navbar{background:var(--auth-card-bg);backdrop-filter:blur(20px);border-bottom:1px solid var(--auth-card-border);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100}.auth-navbar-brand{font-size:1.5rem;font-weight:700;color:var(--auth-text-primary);text-decoration:none}.auth-navbar-user{display:flex;align-items:center;gap:1rem}.dark-mode-toggle{background:none;border:none;color:var(--auth-text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;border-radius:var(--auth-radius-md);transition:all var(--auth-transition-fast)}.dark-mode-toggle:hover{background:var(--auth-input-border);color:var(--auth-text-primary)}.dark-mode-toggle svg{width:20px;height:20px}.user-dropdown{position:relative}.user-avatar{width:40px;height:40px;border-radius:var(--auth-radius-full);background:var(--auth-primary);color:white;display:flex;align-items:center;justify-content:center;font-weight:600;cursor:pointer;transition:transform var(--auth-transition-fast)}.user-avatar:hover{transform:scale(1.1)}.dropdown-menu{position:absolute;top:calc(100% + .5rem);right:0;background:var(--auth-card-bg);backdrop-filter:blur(20px);border:1px solid var(--auth-card-border);border-radius:var(--auth-radius-md);box-shadow:0 8px 24px var(--auth-shadow);min-width:200px;padding:.5rem;display:none;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu.show{display:block}.dropdown-item{padding:.75rem 1rem;color:var(--auth-text-primary);text-decoration:none;display:flex;align-items:center;gap:.75rem;border-radius:var(--auth-radius-sm);transition:background var(--auth-transition-fast)}.dropdown-item:hover{background:var(--auth-input-border)}.dropdown-item svg{width:18px;height:18px;color:var(--auth-text-secondary)}.dropdown-divider{height:1px;background:var(--auth-input-border);margin:.5rem 0}@media(max-width: 640px){.auth-page{padding:var(--auth-spacing-sm)}.auth-card{padding:var(--auth-spacing-lg)}.auth-card h1{font-size:1.75rem}.password-requirements{grid-template-columns:1fr}.auth-navbar{padding:1rem}.form-footer{flex-direction:column;gap:var(--auth-spacing-sm);align-items:flex-start}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}*:focus-visible{outline:2px solid var(--auth-primary);outline-offset:2px}@media(prefers-contrast: high){.auth-card{border-width:2px}.form-control{border-width:2px}.btn{border-width:2px}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}@media print{.auth-page{background:white}.auth-card{box-shadow:none;border:1px solid #000}.btn,.oauth-buttons,.dark-mode-toggle{display:none}}.campaigns-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.5rem;margin-bottom:2rem}.campaign-card .campaign-placeholder-image{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, #4a3422 0%, #2c1810 100%);color:#d4b896;font-size:4rem;border-bottom:1px solid rgba(217, 119, 6, 0.4)}.campaign-card .campaign-placeholder-image i{opacity:.5}.campaign-card .campaign-image{width:100%;height:200px;overflow:hidden;background:linear-gradient(135deg, #4a3422 0%, #2c1810 100%)}.campaign-card .campaign-image-tag{width:100%;height:100%;object-fit:cover}.campaign-card .campaign-meta{display:flex;justify-content:space-between;align-items:center;margin:1rem 0;font-size:.875rem}.campaign-card .players-count{color:#d4b896}.campaign-card .campaign-actions{margin-top:1rem}.campaign-dashboard-container{max-width:1400px;margin:0 auto;padding:2rem}.campaign-dashboard-grid{display:grid;grid-template-columns:1fr 350px;gap:2rem;margin-top:2rem}.campaign-dashboard-main{min-width:0}.campaign-dashboard-header{margin-bottom:2rem}.campaign-banner{height:300px;background-size:cover;background-position:center;background:linear-gradient(135deg, #d97706 0%, #92400e 100%);border-radius:16px;overflow:hidden;position:relative;box-shadow:0 10px 30px rgba(139, 92, 246, 0.3)}.campaign-banner-overlay{background:linear-gradient(180deg, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0.7) 100%);height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:2rem;color:white}.campaign-title{font-size:2.5rem;font-weight:700;margin:0 0 .5rem 0;text-shadow:0 2px 8px rgba(0, 0, 0, 0.5);font-family:"Cinzel",serif;letter-spacing:.5px}.campaign-subtitle{font-size:1.125rem;margin:0;opacity:.9;text-shadow:0 1px 4px rgba(0, 0, 0, 0.5)}.campaign-status-badge{position:absolute;top:1.5rem;right:1.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:600;text-transform:uppercase;font-size:.875rem;background:rgba(255, 255, 255, 0.2);backdrop-filter:blur(10px);border:1px solid rgba(255, 255, 255, 0.3)}.campaign-status-badge.active{background:rgba(16, 185, 129, 0.9);border-color:rgba(16, 185, 129, 1)}.campaign-status-badge.completed{background:rgba(107, 114, 128, 0.9);border-color:rgba(107, 114, 128, 1)}.campaign-status-badge.planning{background:rgba(251, 191, 36, 0.9);border-color:rgba(251, 191, 36, 1)}.campaign-quick-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem;margin-top:-3rem;position:relative;z-index:10}.quick-stat{background:linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(249, 250, 251, 0.95) 100%);border:2px solid rgba(139, 92, 246, 0.2);border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 4px 12px rgba(0, 0, 0, 0.1);transition:all .3s ease}.quick-stat:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(139, 92, 246, 0.3);border-color:#d97706}.stat-icon{display:block;font-size:2rem;margin-bottom:.5rem}.stat-value{display:block;font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.stat-label{display:block;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;font-weight:600}.campaign-section{background:white;border:2px solid rgba(139, 92, 246, 0.1);border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.05);transition:all .3s ease}.campaign-section:hover{box-shadow:0 4px 16px rgba(139, 92, 246, 0.15)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.section-header h2{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0;display:flex;align-items:center;gap:.5rem}.party-roster-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:1.5rem}.party-member-card{background:linear-gradient(135deg, #f9fafb 0%, #ffffff 100%);border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.party-member-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg, #d97706 0%, #92400e 100%);transform:scaleX(0);transition:transform .3s ease}.party-member-card:hover::before{transform:scaleX(1)}.party-member-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px rgba(139, 92, 246, 0.2);border-color:#d97706}.character-mini-avatar{position:relative;width:80px;height:80px;margin:0 auto 1rem}.character-mini-avatar img{width:100%;height:100%;border-radius:50%;border:3px solid #d97706;object-fit:cover;background:linear-gradient(135deg, #e0e7ff 0%, #f3f4f6 100%)}.character-level-badge{position:absolute;bottom:-8px;right:-8px;background:linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);color:#1f2937;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid white;box-shadow:0 2px 6px rgba(0, 0, 0, 0.2)}.character-mini-name{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 .25rem 0;text-align:center}.character-mini-details{font-size:.875rem;color:#6b7280;text-align:center;margin:0 0 .75rem 0}.hp-bar-mini{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.25rem;box-shadow:inset 0 1px 3px rgba(0, 0, 0, 0.1)}.hp-progress{height:100%;transition:width .3s ease;position:relative;overflow:hidden}.hp-progress::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0.2) 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}.hp-progress.success,.hp-progress.green{background:linear-gradient(90deg, #10b981 0%, #059669 100%)}.hp-progress.warning,.hp-progress.yellow{background:linear-gradient(90deg, #f59e0b 0%, #d97706 100%)}.hp-progress.danger,.hp-progress.red{background:linear-gradient(90deg, #ef4444 0%, #dc2626 100%)}.hp-text-mini{font-size:.75rem;color:#6b7280;text-align:center;margin-bottom:.75rem;font-weight:600}.btn-party-action{display:block;width:100%;padding:.5rem;text-align:center;background:linear-gradient(135deg, #d97706 0%, #b45309 100%);color:white;text-decoration:none;border-radius:6px;font-weight:600;transition:all .2s ease;border:none;cursor:pointer}.btn-party-action:hover{background:linear-gradient(135deg, #b45309 0%, #92400e 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.4);color:white}.session-timeline{display:flex;flex-direction:column;gap:1rem}.session-card{background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(109, 40, 217, 0.02) 100%);border:2px solid rgba(139, 92, 246, 0.2);border-radius:12px;padding:1.5rem;display:grid;grid-template-columns:auto 1fr auto auto;gap:1.5rem;align-items:center;transition:all .2s ease;position:relative;overflow:hidden}.session-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg, #d97706 0%, #92400e 100%)}.session-card:hover{border-color:#d97706;box-shadow:0 4px 12px rgba(139, 92, 246, 0.2);transform:translateX(4px)}.session-number{font-size:1.5rem;font-weight:700;color:#d97706;min-width:100px;font-family:"Cinzel",serif}.session-details{flex:1;min-width:0}.session-title{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 .25rem 0}.session-date{font-size:.875rem;color:#6b7280;margin:0 0 .5rem 0}.session-summary{font-size:.875rem;color:#4b5563;margin:0;line-height:1.5}.session-participants{font-size:.875rem;color:#6b7280;white-space:nowrap;padding:.5rem 1rem;background:rgba(139, 92, 246, 0.1);border-radius:6px;font-weight:600}.btn-session-action{padding:.5rem 1rem;background:linear-gradient(135deg, #d97706 0%, #b45309 100%);color:white;text-decoration:none;border-radius:6px;font-weight:600;white-space:nowrap;transition:all .2s ease}.btn-session-action:hover{background:linear-gradient(135deg, #b45309 0%, #92400e 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.4);color:white}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(250px, 1fr));gap:1rem}.note-card{background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px rgba(251, 191, 36, 0.2);transition:all .3s ease;position:relative;min-height:150px}.note-card::before{content:"📌";position:absolute;top:-10px;right:1rem;font-size:1.5rem;transform:rotate(15deg)}.note-card:hover{transform:translateY(-4px) rotate(-1deg);box-shadow:0 6px 16px rgba(251, 191, 36, 0.3)}.note-title{font-size:1.125rem;font-weight:700;color:#92400e;margin:0 0 .5rem 0}.note-category{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#b45309;margin:0 0 .75rem 0;font-weight:600}.note-preview{font-size:.875rem;color:#78350f;margin:0 0 .75rem 0;line-height:1.5}.note-link{font-size:.875rem;font-weight:600;color:#92400e;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.note-link:hover{color:#78350f;text-decoration:underline}.lore-entries{display:grid;grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));gap:1rem}.lore-card{background:white;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;position:relative;transition:all .3s ease;min-height:120px}.lore-card:hover{border-color:#d97706;box-shadow:0 4px 12px rgba(139, 92, 246, 0.15)}.lore-type-badge{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#f3f4f6;color:#4b5563;letter-spacing:.05em}.lore-type-badge.location{background:#dbeafe;color:#1e40af}.lore-type-badge.npc{background:#fce7f3;color:#9f1239}.lore-type-badge.faction{background:#fef3c7;color:#92400e}.lore-type-badge.history{background:#e0e7ff;color:#4338ca}.lore-title{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 .75rem 0;padding-right:100px}.lore-preview{font-size:.875rem;color:#6b7280;margin:0;line-height:1.5}.campaign-info-sidebar{display:flex;flex-direction:column;gap:1.5rem}.info-card{background:white;border:2px solid rgba(139, 92, 246, 0.1);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.05)}.info-card h3{font-size:1.125rem;font-weight:700;color:#1f2937;margin:0 0 1rem 0;padding-bottom:.75rem;border-bottom:2px solid #e5e7eb}.info-card p{font-size:.875rem;color:#4b5563;line-height:1.6;margin:0}.settings-list{list-style:none;padding:0;margin:0}.settings-list li{font-size:.875rem;color:#4b5563;padding:.5rem 0;border-bottom:1px solid #f3f4f6}.settings-list li:last-child{border-bottom:none}.settings-list li strong{color:#1f2937;font-weight:600;display:inline-block;min-width:140px}.empty-party-state,.empty-session-state,.empty-notes-state,.empty-lore-state{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(109, 40, 217, 0.02) 100%);border:2px dashed rgba(139, 92, 246, 0.3);border-radius:12px}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.7}.empty-state-text{font-size:1.125rem;color:#6b7280;margin-bottom:1.5rem;font-weight:500}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-weight:600;text-decoration:none;transition:all .2s ease;border:none;cursor:pointer}.btn-primary{background:linear-gradient(135deg, #d97706 0%, #b45309 100%);color:white}.btn-primary:hover{background:linear-gradient(135deg, #b45309 0%, #92400e 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.4);color:white}.btn-sm{font-size:.875rem;padding:.375rem .75rem}.btn-secondary{background:#e5e7eb;color:#4b5563}.btn-secondary:hover{background:#d1d5db;color:#1f2937}.view-all-link{display:block;text-align:center;padding:1rem;color:#d97706;font-weight:600;text-decoration:none;margin-top:1rem;border-radius:8px;transition:all .2s ease}.view-all-link:hover{background:rgba(139, 92, 246, 0.05);color:#b45309}@media(max-width: 1024px){.campaign-dashboard-grid{grid-template-columns:1fr}.campaign-info-sidebar{grid-row:auto}}@media(max-width: 768px){.campaign-dashboard-container{padding:1rem}.campaign-title{font-size:1.75rem}.campaign-banner{height:200px}.campaign-quick-stats{grid-template-columns:repeat(2, 1fr);margin-top:1rem}.party-roster-grid{grid-template-columns:1fr}.session-card{grid-template-columns:1fr;text-align:left;gap:1rem}.session-number{margin-bottom:0}.session-participants,.btn-session-action{width:100%;text-align:center}.notes-grid,.lore-entries{grid-template-columns:1fr}.campaign-section{padding:1.5rem}}@media(max-width: 480px){.campaign-quick-stats{grid-template-columns:1fr}.campaign-banner{height:160px}.campaign-title{font-size:1.5rem}.campaign-subtitle{font-size:1rem}}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.5rem;margin-top:2rem}.character-card{background:linear-gradient(135deg, #ffffff 0%, #f9fafb 100%);border:2px solid #e5e7eb;border-radius:16px;overflow:hidden;transition:all .3s ease;box-shadow:0 4px 6px rgba(0, 0, 0, 0.1);position:relative}.character-card:hover{transform:translateY(-8px);box-shadow:0 12px 24px rgba(139, 92, 246, 0.3);border-color:#d97706}.character-card.archived{opacity:.6;border-color:#fbbf24;background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%)}.character-card.archived::before{content:"📦 ARCHIVED";position:absolute;top:10px;left:10px;background:rgba(251, 191, 36, 0.9);color:#1f2937;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;z-index:10;letter-spacing:.05em}.character-avatar-section{position:relative;height:220px;background:linear-gradient(135deg, #d97706 0%, #92400e 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}.character-card-avatar{width:150px;height:150px;border-radius:50%;border:4px solid #fff;object-fit:cover;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3)}.character-avatar-placeholder{width:150px;height:150px;border-radius:50%;border:4px solid #fff;background:linear-gradient(135deg, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.1) 100%);display:flex;align-items:center;justify-content:center;font-size:4rem;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3)}.character-level-badge{position:absolute;top:12px;right:12px;background:linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);color:#1f2937;padding:.5rem 1rem;border-radius:12px;font-weight:700;box-shadow:0 2px 8px rgba(251, 191, 36, 0.5);text-align:center;min-width:60px}.level-number{display:block;font-size:1.5rem;line-height:1}.level-label{display:block;font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;margin-top:.125rem}.character-card-body{padding:1.5rem}.character-card-name{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0 0 .5rem 0;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.character-card-details{font-size:1rem;color:#6b7280;margin:0 0 .25rem 0;font-weight:600}.character-card-background{font-size:.875rem;color:#9ca3af;margin:0 0 .5rem 0;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.character-card-campaign{font-size:.875rem;color:#d97706;margin:0 0 1rem 0;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hp-bar-container{margin-bottom:1rem}.hp-label{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;font-weight:600;margin-bottom:.25rem;color:#4b5563}.hp-bar{height:20px;background:#e5e7eb;border-radius:10px;overflow:hidden;position:relative}.hp-progress{height:100%;transition:width .3s ease;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:white;position:relative}.hp-progress.success,.hp-progress.green{background:linear-gradient(90deg, #10b981 0%, #059669 100%)}.hp-progress.warning,.hp-progress.yellow{background:linear-gradient(90deg, #f59e0b 0%, #d97706 100%)}.hp-progress.danger,.hp-progress.red{background:linear-gradient(90deg, #ef4444 0%, #dc2626 100%)}.character-quick-stats{display:grid;grid-template-columns:repeat(3, 1fr);gap:.75rem;margin-bottom:1rem}.quick-stat{text-align:center;padding:.75rem;background:linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(109, 40, 217, 0.05) 100%);border-radius:8px;border:1px solid rgba(139, 92, 246, 0.2)}.stat-icon{display:block;font-size:1.25rem;margin-bottom:.25rem}.stat-value{display:block;font-size:1.125rem;font-weight:700;color:#1f2937;margin-bottom:.125rem}.stat-label{display:block;font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.character-card-actions{display:flex;gap:.5rem;padding:0 1.5rem 1.5rem;flex-wrap:wrap}.btn-card-action{flex:1;padding:.625rem 1rem;font-size:.875rem;font-weight:600;border-radius:8px;text-align:center;text-decoration:none;transition:all .2s ease;border:2px solid transparent;display:inline-block;cursor:pointer;min-width:100px}.btn-card-action.btn-primary{background:linear-gradient(135deg, #d97706 0%, #92400e 100%);color:white}.btn-card-action.btn-primary:hover{background:linear-gradient(135deg, #b45309 0%, #78350f 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.4)}.btn-card-action.btn-secondary{background:#f3f4f6;color:#4b5563;border-color:#d1d5db}.btn-card-action.btn-secondary:hover{background:#e5e7eb;border-color:#9ca3af}.btn-card-action.btn-success{background:linear-gradient(135deg, #10b981 0%, #059669 100%);color:white}.btn-card-action.btn-success:hover{background:linear-gradient(135deg, #059669 0%, #047857 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(16, 185, 129, 0.4)}.btn-card-action.btn-warning{background:linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);color:#1f2937}.btn-card-action.btn-warning:hover{background:linear-gradient(135deg, #f59e0b 0%, #d97706 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(251, 191, 36, 0.4)}.filters-section-enhanced{background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(109, 40, 217, 0.02) 100%);border:2px solid rgba(139, 92, 246, 0.2);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column}.filter-group label{display:block;font-size:.875rem;font-weight:600;color:#4b5563;margin-bottom:.5rem}.filter-group .form-control,.filter-group .form-select{width:100%}.range-inputs{display:flex;gap:.5rem;align-items:center}.range-inputs .form-control{flex:1}.range-inputs span{color:#6b7280;font-size:.875rem;font-weight:500}.filter-actions{display:flex;gap:.5rem;flex-wrap:wrap}.filter-actions .btn{white-space:nowrap}.view-switcher{display:flex;gap:.5rem;margin-bottom:1.5rem;border:2px solid #e5e7eb;border-radius:8px;padding:.25rem;background:#f9fafb;width:fit-content}.view-option{padding:.5rem 1rem;border-radius:6px;text-decoration:none;color:#6b7280;font-weight:500;transition:all .2s ease;font-size:.875rem}.view-option.active{background:#d97706;color:white;box-shadow:0 2px 4px rgba(139, 92, 246, 0.3)}.view-option:hover:not(.active){background:#e5e7eb;color:#1f2937}.characters-empty-state{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(109, 40, 217, 0.02) 100%);border:2px dashed rgba(139, 92, 246, 0.3);border-radius:16px;margin-top:2rem}.empty-state-icon{font-size:4rem;margin-bottom:1rem;display:block}.empty-state-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.empty-state-text{font-size:1rem;color:#6b7280;margin-bottom:1.5rem}.stats-overview-cards{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem;margin-bottom:2rem}.stat-overview-card{background:linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(109, 40, 217, 0.05) 100%);border:2px solid rgba(139, 92, 246, 0.2);border-radius:12px;padding:1.5rem;text-align:center}.stat-overview-icon{font-size:2rem;margin-bottom:.5rem;display:block}.stat-overview-value{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.25rem;display:block}.stat-overview-label{font-size:.875rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-weight:600}@media(max-width: 768px){.characters-grid{grid-template-columns:1fr}.filters-grid{grid-template-columns:1fr}.character-card-actions{flex-direction:column}.btn-card-action{width:100%}.view-switcher{width:100%}.view-option{flex:1;text-align:center}.stats-overview-cards{grid-template-columns:1fr}.character-quick-stats{grid-template-columns:repeat(3, 1fr)}}@media(max-width: 480px){.character-avatar-section{height:180px}.character-card-avatar,.character-avatar-placeholder{width:120px;height:120px}.character-level-badge{top:8px;right:8px;padding:.375rem .75rem}.level-number{font-size:1.25rem}.character-card-name{font-size:1.25rem}.character-quick-stats{gap:.5rem}.quick-stat{padding:.5rem}.stat-icon{font-size:1rem}.stat-value{font-size:.875rem}}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.character-card{animation:fadeInUp .3s ease-out}.characters-loading{text-align:center;padding:3rem;color:#6b7280;font-size:1.125rem}.characters-loading::before{content:"⚔️";display:block;font-size:3rem;margin-bottom:1rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.pagination-wrapper{margin-top:2rem;display:flex;justify-content:center}.character-sheet-container{max-width:1400px;margin:0 auto;padding:var(--space-lg);background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(236, 72, 153, 0.05) 100%);min-height:100vh}.quick-actions-bar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--card-bg);backdrop-filter:var(--card-backdrop-filter);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:var(--card-border-width) solid var(--card-border-color);transition:all var(--transition-base) var(--ease-in-out)}.actions-left,.actions-center,.actions-right{display:flex;gap:var(--space-sm)}.actions-center{flex:1;justify-content:center}.dice-icon{font-size:1.2em}.character-header{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-lg);align-items:center;padding:var(--space-lg);margin-bottom:var(--space-lg);background:linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(236, 72, 153, 0.1) 100%);border:var(--card-border-width) solid rgba(139, 92, 246, 0.3);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.character-avatar{width:120px;height:120px;border-radius:var(--radius-lg);overflow:hidden;border:3px solid var(--color-gold);box-shadow:0 4px 12px rgba(212, 175, 55, 0.3)}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--gradient-purple);display:flex;align-items:center;justify-content:center;font-size:var(--font-5xl)}.character-identity{flex:1}.character-name{font-size:var(--font-4xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-sm) 0;color:var(--text-primary);text-shadow:2px 2px 4px rgba(0, 0, 0, 0.1)}.character-subtitle{font-size:var(--font-xl);color:var(--text-secondary);margin-bottom:var(--space-sm)}.race-class{font-weight:var(--font-weight-semibold);color:var(--color-gold-dark)}.background{color:var(--text-secondary);font-style:italic}.character-meta{font-size:var(--font-base);color:var(--text-secondary)}.character-level-xp{display:flex;flex-direction:column;gap:var(--space-md);min-width:200px}.level-display{text-align:center;padding:var(--space-md);background:var(--gradient-purple);border-radius:var(--radius-lg);color:white;box-shadow:var(--shadow-md);transition:all var(--transition-base) var(--ease-in-out)}.level-display:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.level-number{font-size:var(--font-5xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.level-label{font-size:var(--font-sm);text-transform:uppercase;letter-spacing:1px;opacity:.9}.xp-display{padding:var(--space-md);background:rgba(255, 255, 255, 0.8);border-radius:var(--radius-md);border:1px solid rgba(139, 92, 246, 0.2)}.xp-current{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-base)}.xp-next{font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-xs)}.bg-purple{background:var(--gradient-purple) !important}.sheet-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);align-items:start}.sheet-column-left,.sheet-column-right{display:flex;flex-direction:column;gap:var(--space-lg)}.section-title{font-size:var(--font-xl);font-weight:var(--font-weight-bold);margin:0 0 var(--space-md) 0;padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-gold-dark);color:var(--text-primary);text-transform:uppercase;letter-spacing:1px}.ability-scores-section{background:var(--card-bg);backdrop-filter:var(--card-backdrop-filter);padding:var(--card-padding);border-radius:var(--radius-lg);border:var(--card-border-width) solid rgba(212, 175, 55, 0.3);box-shadow:var(--shadow-md);transition:all var(--transition-base) var(--ease-in-out)}.ability-scores-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.ability-scores-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:var(--space-md)}.ability-score-box{background:white;border:2px solid var(--color-gold);border-radius:var(--radius-lg);padding:var(--space-md);text-align:center;cursor:pointer;transition:all var(--transition-fast) var(--ease-in-out);box-shadow:var(--shadow-sm);min-height:var(--touch-target-min)}.ability-score-box:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-gold-dark)}.ability-score-box:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset);box-shadow:var(--focus-ring-shadow)}.ability-name{font-size:var(--font-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.ability-score{font-size:var(--font-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight);margin-bottom:var(--space-xs)}.ability-modifier{font-size:var(--font-xl);font-weight:var(--font-weight-semibold);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);display:inline-block}.ability-modifier.positive{color:var(--color-success);background:rgba(16, 185, 129, 0.1)}.ability-modifier.negative{color:var(--color-danger);background:rgba(220, 38, 38, 0.1)}.combat-stats-section{background:var(--card-bg);backdrop-filter:var(--card-backdrop-filter);padding:var(--card-padding);border-radius:var(--radius-lg);border:var(--card-border-width) solid rgba(239, 68, 68, 0.3);box-shadow:var(--shadow-md);transition:all var(--transition-base) var(--ease-in-out)}.combat-stats-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.hp-display{margin-bottom:var(--space-lg);padding:var(--space-md);background:white;border-radius:var(--radius-lg);border:2px solid rgba(239, 68, 68, 0.3);cursor:pointer;transition:all var(--transition-fast) var(--ease-in-out)}.hp-display:hover{border-color:var(--color-gold-dark);box-shadow:var(--shadow-md)}.hp-label{font-size:var(--font-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.hp-bar-container{position:relative}.hp-bar{height:32px;background:var(--color-gray-200);border-radius:var(--radius-md);overflow:hidden;position:relative;border:2px solid var(--color-gray-300)}.hp-bar-fill{height:100%;transition:width var(--transition-base) var(--ease-in-out);display:flex;align-items:center;justify-content:center}.hp-text{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);font-weight:var(--font-weight-bold);font-size:var(--font-lg);color:var(--text-primary);text-shadow:0 1px 2px rgba(255, 255, 255, 0.8);z-index:var(--z-base)}.hp-separator{margin:0 var(--space-xs);opacity:.6}.temp-hp-display{margin-top:var(--space-sm);padding:var(--space-sm);background:rgba(59, 130, 246, 0.1);border-radius:var(--radius-md);text-align:center;font-size:var(--font-sm)}.temp-hp-label{font-weight:var(--font-weight-semibold);color:var(--color-info)}.temp-hp-value{font-weight:var(--font-weight-bold);color:#1e40af;margin-left:var(--space-sm)}.combat-stats-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:var(--space-md);margin-bottom:var(--space-md)}.stat-box{background:white;padding:var(--space-md);border-radius:var(--radius-md);border:1px solid rgba(0, 0, 0, 0.1);text-align:center;box-shadow:var(--shadow-sm);transition:all var(--transition-fast) var(--ease-in-out)}.stat-box:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-label{font-size:var(--font-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.stat-value{font-size:var(--font-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.hit-dice-display{background:white;padding:var(--space-md);border-radius:var(--radius-md);border:1px solid rgba(0, 0, 0, 0.1);text-align:center;box-shadow:var(--shadow-sm)}.saving-throws-section,.skills-section{background:var(--card-bg);backdrop-filter:var(--card-backdrop-filter);padding:var(--card-padding);border-radius:var(--radius-lg);border:var(--card-border-width) solid rgba(59, 130, 246, 0.3);box-shadow:var(--shadow-md);transition:all var(--transition-base) var(--ease-in-out)}.saving-throws-section:hover,.skills-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.saves-list,.skills-list{display:flex;flex-direction:column;gap:var(--space-sm)}.save-item,.skill-item{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-md);align-items:center;padding:var(--space-md);background:white;border-radius:var(--radius-md);border:1px solid rgba(0, 0, 0, 0.1);cursor:pointer;transition:all var(--transition-fast) var(--ease-in-out);min-height:var(--touch-target-min)}.save-item:hover,.skill-item:hover{background:rgba(139, 92, 246, 0.05);border-color:var(--color-gold-dark);transform:translateX(4px);box-shadow:var(--shadow-sm)}.save-item:focus-visible,.skill-item:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.proficiency-indicator{font-size:var(--font-xl);color:var(--color-gray-300)}.proficiency-indicator.proficient{color:var(--color-gold);filter:drop-shadow(0 0 4px rgba(212, 175, 55, 0.5))}.proficiency-indicator.expertise{color:var(--color-gold-dark);filter:drop-shadow(0 0 4px rgba(139, 92, 246, 0.5))}.save-name,.skill-name{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-sm)}.skill-ability{font-size:var(--font-xs);color:var(--text-secondary);font-weight:var(--font-weight-normal);margin-left:var(--space-xs)}.save-bonus,.skill-bonus{font-weight:var(--font-weight-bold);font-size:var(--font-base);min-width:40px;text-align:right}.save-bonus.positive,.skill-bonus.positive{color:var(--color-success)}.save-bonus.negative,.skill-bonus.negative{color:var(--color-danger)}.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section{background:var(--card-bg);backdrop-filter:var(--card-backdrop-filter);padding:var(--card-padding);border-radius:var(--radius-lg);border:var(--card-border-width) solid rgba(245, 158, 11, 0.3);box-shadow:var(--shadow-md);transition:all var(--transition-base) var(--ease-in-out)}.features-section:hover,.personality-section:hover,.equipment-section:hover,.spells-section:hover,.backstory-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.features-content,.personality-content,.equipment-content,.spells-content,.backstory-content{color:var(--text-primary)}.feature-group,.equipment-group,.spell-level-group{margin-bottom:var(--space-lg)}.feature-group:last-child,.equipment-group:last-child,.spell-level-group:last-child{margin-bottom:0}.feature-group-title,.equipment-group-title,.spell-level-title{font-size:var(--font-base);font-weight:var(--font-weight-bold);color:var(--color-gold-dark);margin-bottom:var(--space-md);text-transform:uppercase;letter-spacing:.5px}.feature-text{color:var(--text-secondary);line-height:var(--line-height-normal)}.personality-item{margin-bottom:var(--space-md);padding:var(--space-md);background:white;border-radius:var(--radius-md);border-left:4px solid var(--color-gold-dark);box-shadow:var(--shadow-sm)}.personality-item:last-child{margin-bottom:0}.personality-item strong{color:var(--color-gold-dark);display:block;margin-bottom:var(--space-xs)}.equipment-list,.spell-list{display:flex;flex-direction:column;gap:var(--space-sm)}.equipment-item,.spell-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:white;border-radius:var(--radius-md);border:1px solid rgba(0, 0, 0, 0.1);box-shadow:var(--shadow-sm);transition:all var(--transition-fast) var(--ease-in-out)}.equipment-item:hover,.spell-item:hover{box-shadow:var(--shadow-md);transform:translateX(2px)}.equipment-item.equipped{border-left:4px solid var(--color-success);background:rgba(16, 185, 129, 0.05)}.item-icon{font-size:var(--font-xl)}.item-name,.spell-name{flex:1;font-weight:var(--font-weight-semibold);color:var(--text-primary)}.item-quantity{color:var(--text-secondary);font-size:var(--font-sm)}.spell-slots{margin-bottom:var(--space-lg);padding:var(--space-md);background:white;border-radius:var(--radius-md);border:1px solid rgba(0, 0, 0, 0.1);box-shadow:var(--shadow-sm)}.spell-slot-level{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.spell-slot-level:last-child{margin-bottom:0}.slot-label{font-weight:var(--font-weight-semibold);color:var(--text-primary);min-width:100px}.slot-tracker{display:flex;gap:var(--space-sm)}.spell-slot{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:var(--font-xl);cursor:pointer;transition:all var(--transition-fast) var(--ease-in-out);border:2px solid var(--color-gold-dark)}.spell-slot.available{color:var(--color-gold-dark);background:white}.spell-slot.used{color:var(--text-tertiary);background:var(--color-gray-200);border-color:var(--color-gray-400)}.spell-slot:hover{transform:scale(1.1);box-shadow:var(--shadow-sm)}.spell-slot:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}@media(hover: none)and (pointer: coarse){.spell-slot{width:var(--touch-target-min);height:var(--touch-target-min);font-size:var(--font-2xl)}.ability-score-box{min-height:60px;padding:var(--space-md)}.skill-item,.save-item{min-height:52px;padding:var(--space-md)}}.hp-adjustment-controls{padding:var(--space-md) 0}.current-hp-display{text-align:center;font-size:var(--font-xl);margin-bottom:var(--space-lg);padding:var(--space-md);background:rgba(139, 92, 246, 0.1);border-radius:var(--radius-md)}.hp-buttons{display:flex;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-lg);flex-wrap:wrap}.roll-toast{min-width:300px;border-left:4px solid var(--color-gold-dark);box-shadow:var(--shadow-lg)}.roll-toast.roll-critical{border-left-color:var(--color-success);background:rgba(16, 185, 129, 0.1)}.roll-toast.roll-fumble{border-left-color:var(--color-danger);background:rgba(220, 38, 38, 0.1)}.roll-result{display:flex;align-items:center;justify-content:center;gap:var(--space-md);font-size:var(--font-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-sm)}.roll-die{color:var(--color-gold-dark);font-size:var(--font-4xl)}.roll-modifier{color:var(--text-secondary)}.roll-equals{color:var(--text-tertiary);font-weight:var(--font-weight-normal)}.roll-total{color:var(--text-primary);font-size:var(--font-4xl)}.roll-type-label{text-align:center;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:1px;font-size:var(--font-sm);margin-top:var(--space-sm)}.roll-toast.roll-critical .roll-type-label{color:var(--color-success)}.roll-toast.roll-fumble .roll-type-label{color:var(--color-danger)}@media(max-width: 1024px){.sheet-layout{grid-template-columns:1fr}.ability-scores-grid{grid-template-columns:repeat(6, 1fr)}.character-header{grid-template-columns:1fr;text-align:center}.character-avatar{margin:0 auto}}@media(max-width: 768px){.character-sheet-container{padding:var(--space-md)}.quick-actions-bar{flex-direction:column}.actions-left,.actions-center,.actions-right{width:100%;justify-content:center}.ability-scores-grid{grid-template-columns:repeat(3, 1fr)}.character-name{font-size:var(--font-3xl)}.combat-stats-grid{grid-template-columns:1fr}}@media(max-width: 480px){.ability-scores-grid{grid-template-columns:repeat(2, 1fr)}.level-number{font-size:var(--font-3xl)}.hp-buttons{flex-direction:column}.hp-buttons button{width:100%}}.ability-score-box:focus-visible,.save-item:focus-visible,.skill-item:focus-visible,.spell-slot:focus-visible,.hp-display:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset);box-shadow:var(--focus-ring-shadow)}@media print{.quick-actions-bar{display:none}.character-sheet-container{background:white;padding:0}.ability-scores-section,.combat-stats-section,.saving-throws-section,.skills-section,.features-section,.personality-section,.equipment-section,.spells-section,.backstory-section{break-inside:avoid}.ability-score-box:hover,.save-item:hover,.skill-item:hover{transform:none;box-shadow:none}}.character-sheet-container.edit-mode .ability-score-box,.character-sheet-container.edit-mode .save-item,.character-sheet-container.edit-mode .skill-item{cursor:default;pointer-events:none}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}.ability-score-box:hover,.save-item:hover,.skill-item:hover,.equipment-item:hover,.spell-item:hover{transform:none !important}}@media print{@page{size:letter portrait;margin:.4in .5in}.btn,button,.modal,.modal-backdrop,.navbar,nav,header,footer,.top-header,.sidebar,.sidebar-brand,.sidebar-nav,.breadcrumb,.alert,.dropdown,.quick-actions,.quick-actions-bar,.hp-buttons,.btn-group,.rest-buttons,.short-rest-button,.long-rest-button,[data-action],[role=button],.clickable,.card-header button,.saving-throw-button,.skill-button,.spell-slot:hover,.ability-score-box:hover{display:none !important}body{background:white !important;color:#000 !important;font-size:9pt;line-height:1.2;font-family:"Georgia","Times New Roman",serif;margin:0;padding:0}.app-wrapper,.main-wrapper{margin:0 !important;padding:0 !important;background:white !important}.main-content{padding:0 !important;margin:0 !important}.container,.container-fluid{width:100% !important;max-width:100% !important;padding:0 !important;margin:0 !important}.card{border:1px solid #333 !important;box-shadow:none !important;margin-bottom:.3rem !important;page-break-inside:avoid;background:white !important;border-radius:0 !important}.card-header{background-color:#e8e8e8 !important;color:#000 !important;border-bottom:1px solid #333 !important;padding:.2rem .4rem !important;font-size:10pt;font-weight:bold;-webkit-print-color-adjust:exact;print-color-adjust:exact}.card-body{padding:.3rem .4rem !important}.container-fluid>.row:first-child::before{content:"D&D 5E CHARACTER SHEET";display:block;text-align:center;font-size:14pt;font-weight:bold;margin-bottom:.4rem;padding-bottom:.3rem;border-bottom:2px solid #000;letter-spacing:2px}.card:first-child .card-body h2{font-size:16pt !important;margin:0 0 .2rem 0 !important;color:#000 !important}.card:first-child .card-body p,.card:first-child .card-body small{font-size:9pt !important;margin:.1rem 0 !important;color:#000 !important}.row{display:flex !important;flex-wrap:wrap !important;margin:0 !important;page-break-inside:avoid}.col-md-4{flex:0 0 33.333% !important;max-width:33.333% !important;padding:0 .2rem !important}.ability-scores .card-body{padding:.3rem !important}.ability-scores .row{gap:.15rem}.ability-score,.ability-score-box{border:1px solid #333 !important;padding:.2rem !important;text-align:center;page-break-inside:avoid;background:white !important}.ability-name{font-size:7pt !important;font-weight:bold !important;text-transform:uppercase;color:#000 !important}.ability-value,.ability-score{font-size:12pt !important;font-weight:bold !important;color:#000 !important}.ability-modifier{font-size:10pt !important;color:#000 !important}.card-body .d-flex{display:flex !important;justify-content:space-between !important;margin-bottom:.15rem !important;font-size:8pt}.card-body .d-flex span:first-child{font-weight:normal}.card-body .d-flex strong{font-weight:bold;color:#000 !important}.hp-bar,.hit-points{border:2px solid #333 !important;padding:.3rem !important;page-break-inside:avoid}.hp-display .h1,.current-hp{font-size:14pt !important;font-weight:bold !important;color:#000 !important;text-align:center;margin:.2rem 0 !important}.temp-hp{font-size:8pt !important;color:#000 !important}.progress{background-color:#e9ecef !important;border:1px solid #333 !important;height:16px !important;-webkit-print-color-adjust:exact;print-color-adjust:exact;margin-bottom:.2rem !important}.progress-bar{background-color:#666 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.death-saves,#death-saves-container{border:1.5px solid #333 !important;page-break-inside:avoid;margin-bottom:.3rem !important}.death-save-circle{font-size:10pt !important;margin:0 .15rem;color:#000 !important}.death-save-circle.filled.bg-success{color:#000 !important}.death-save-circle.filled.bg-danger{color:#000 !important}.saving-throws .card-body{padding:.3rem !important}.saving-throws .d-flex{padding:.1rem 0 !important;border-bottom:1px dotted #ccc !important;font-size:8pt}.saving-throws .fw-bold{font-weight:bold !important}.skills .card-body{max-height:none !important;overflow:visible !important;padding:.3rem !important}.skills .d-flex{padding:.08rem 0 !important;font-size:7.5pt;border-bottom:1px dotted #ddd !important;page-break-inside:avoid}.skills .fw-bold{font-weight:bold !important}.skills small{font-size:6.5pt !important;color:#666 !important}.conditions,.active-conditions{page-break-inside:avoid}.condition-item,.conditions-panel .badge{border:1px solid #333 !important;padding:.15rem .3rem !important;margin:.1rem !important;font-size:8pt;display:inline-block;background:white !important;color:#000 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.resources,.resources-panel{font-size:8pt;page-break-inside:avoid}.spell-slot-level{padding:.1rem 0 !important;margin-bottom:.1rem !important;border-bottom:1px dotted #ccc !important}.spell-slot-level .d-flex{display:flex !important;justify-content:space-between !important}.slot-tracker{font-weight:bold}.notes,.notes-panel{page-break-inside:avoid}.nav-tabs,.tab-pane:not(.show):not(.active),.search-bar,.input-group,.modal,.dropdown,.btn-toolbar,.character-count,.save-status,.tag-badge button,.accordion-button,#quick-note-editor{display:none !important}.tab-pane{display:block !important;opacity:1 !important;page-break-before:auto}.note-item{border:1px solid #ccc !important;padding:.2rem !important;margin-bottom:.2rem !important;font-size:8pt;page-break-inside:avoid;background:white !important}.note-title{font-size:9pt;font-weight:bold}.note-content,.session-content{font-size:7.5pt;margin-top:.1rem}.session-entry{border:1px solid #333 !important;margin-bottom:.3rem !important;padding:.2rem !important;page-break-inside:avoid}.session-entry .accordion-header h2{font-size:10pt !important;font-weight:bold !important;margin:0 !important}.accordion-collapse{display:block !important}.accordion-body{padding:.2rem !important;font-size:8pt}.goal-item{border:1px solid #666 !important;padding:.2rem !important;margin-bottom:.2rem !important;page-break-inside:avoid}.goal-item.completed{opacity:.6}.goal-title{font-size:9pt !important;font-weight:bold !important}.goal-item.completed .goal-title{text-decoration:line-through}.form-check-input{-webkit-print-color-adjust:exact;print-color-adjust:exact}.npc-card{border-left:3px solid #333 !important;padding:.2rem !important;margin-bottom:.2rem !important;page-break-inside:avoid}.npc-card .card-title{font-size:9pt !important;font-weight:bold !important;margin-bottom:.1rem !important}.relationship-positive{border-left-color:#000 !important}.relationship-negative{border-left-color:#666 !important}.tag-badge,.badge{border:1px solid #333 !important;padding:.1rem .2rem !important;margin:.05rem !important;font-size:7pt !important;display:inline-block !important;background:white !important;color:#000 !important}.border-warning{border-color:#333 !important;border-width:2px !important}.tab-pane::before{display:block;font-size:11pt;font-weight:bold;margin:.3rem 0;padding-bottom:.2rem;border-bottom:1px solid #333}#quick-notes::before{content:"QUICK NOTES"}#session-journal::before{content:"SESSION JOURNAL"}#goals::before{content:"GOALS & QUESTS"}#npcs::before{content:"NPCs & RELATIONSHIPS"}.session-content ul,.npc-card ul{margin:.2rem 0 !important;padding-left:1rem !important;list-style:none !important}.session-content ul li,.npc-card ul li{font-size:7.5pt !important;margin-bottom:.1rem !important}.bi,i{font-size:inherit !important}*,.text-muted,.text-white,.bg-primary,.bg-danger,.bg-success,.bg-info,.bg-warning,.card-header.bg-primary,.card-header.bg-danger,.card-header.bg-success,.card-header.bg-info,.card-header.bg-warning{color:#000 !important}*,*::before,*::after{animation:none !important;transition:none !important;box-shadow:none !important;text-shadow:none !important}a{text-decoration:none !important;color:#000 !important}.mb-3,.mb-2,.mb-1{margin-bottom:.2rem !important}.ability-scores,.saving-throws,.skills,.hit-points,.conditions,.resources,.notes{page-break-inside:avoid;page-break-after:auto}.col-md-4:last-child{page-break-before:auto}.card:empty,.card-body:empty{display:none !important}h1,h2,h3,h4,h5,h6{color:#000 !important;page-break-after:avoid}p{orphans:3;widows:3}.border,.border-rounded,.rounded{border:1px solid #333 !important;border-radius:0 !important}.print-view-container{max-width:100% !important;margin:0 !important;padding:0 !important}.print-character-header{border:2px solid #000 !important;padding:.4rem !important;margin-bottom:.4rem !important;page-break-inside:avoid;background:white !important}.print-character-name{font-size:18pt !important;font-weight:bold !important;margin:0 !important;color:#000 !important}.print-character-info{font-size:9pt !important;margin-top:.2rem !important;color:#000 !important}.print-three-column{display:flex !important;gap:.3rem;page-break-inside:avoid}.print-column{flex:1;page-break-inside:avoid}.print-section{border:1px solid #333 !important;margin-bottom:.3rem !important;page-break-inside:avoid;background:white !important}.print-section-header{background-color:#e8e8e8 !important;color:#000 !important;padding:.2rem .4rem !important;font-size:10pt !important;font-weight:bold !important;border-bottom:1px solid #333 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.print-section-body{padding:.3rem .4rem !important}.print-stat-grid{display:grid !important;grid-template-columns:repeat(3, 1fr);gap:.2rem}.print-stat-box{border:1px solid #333 !important;padding:.2rem !important;text-align:center;page-break-inside:avoid}.print-stat-label{font-size:7pt !important;text-transform:uppercase;font-weight:bold !important;color:#000 !important}.print-stat-value{font-size:11pt !important;font-weight:bold !important;color:#000 !important}.print-list-item{border-bottom:1px dotted #ccc !important;padding:.1rem 0 !important;font-size:8pt;display:flex;justify-content:space-between}.print-list-item:last-child{border-bottom:none !important}.print-text-content{font-size:8pt !important;line-height:1.3 !important;color:#000 !important}.print-two-column{display:flex !important;gap:.3rem}.print-half{flex:1}.print-actions,.print-hide{display:none !important}.print-equipment-item{padding:.1rem 0 !important;border-bottom:1px dotted #ddd !important;font-size:8pt}.print-equipment-item:last-child{border-bottom:none !important}.print-spell-level{margin-bottom:.2rem !important;page-break-inside:avoid}.print-spell-level-title{font-size:9pt !important;font-weight:bold !important;border-bottom:1px solid #666 !important;padding-bottom:.1rem !important;margin-bottom:.1rem !important}.print-spell-item{font-size:7.5pt !important;padding:.05rem 0 !important}.print-feature{margin-bottom:.2rem !important;page-break-inside:avoid}.print-feature-name{font-weight:bold !important;font-size:8pt !important}.print-feature-description{font-size:7.5pt !important;margin-left:.3rem !important}body::after{content:"Generated by Heretical RPG - Character Sheet";display:block;text-align:center;font-size:7pt;color:#999;margin-top:.5rem;padding-top:.3rem;border-top:1px solid #ccc;page-break-before:avoid}@supports(-webkit-appearance: none) and (stroke-color: transparent){.row{display:-webkit-flex !important;-webkit-flex-wrap:wrap !important}.col-md-4{-webkit-flex:0 0 33.333% !important}@page{margin:.5in .6in}.card,.ability-score-box,.death-saves,.note-item,.session-entry,.goal-item,.npc-card{-webkit-column-break-inside:avoid !important;break-inside:avoid !important;position:relative;display:block !important}body{-webkit-font-smoothing:subpixel-antialiased !important;-webkit-text-size-adjust:100% !important}.card-header,.progress,.progress-bar,.condition-item,.badge,.form-check-input{-webkit-print-color-adjust:economy !important;color-adjust:economy !important}.d-flex{display:-webkit-flex !important;-webkit-justify-content:space-between !important;-webkit-align-items:center !important}.card,.border,.ability-score-box{border:1.5px solid #333 !important;-webkit-border-radius:0 !important}body{font-size:9.5pt}.card-header{font-size:10.5pt}.ability-value,.ability-score{font-size:12.5pt !important}*{-webkit-transform:none !important;transform:none !important}.card-body{overflow:visible !important;-webkit-overflow-scrolling:auto !important}table{table-layout:fixed !important;width:100% !important}}@media not all and (min-resolution: 0.001dpcm){@supports(-webkit-appearance: none){.row{display:table !important;width:100% !important}.col-md-4{display:table-cell !important;width:33.333% !important;vertical-align:top !important}}}}:root{--combat-primary: #dc3545;--combat-secondary: #d97706;--monster-color: #dc3545;--pc-color: #0d6efd;--dnd-purple: #d97706;--dnd-gold: #fbbf24}.encounter-header{background:linear-gradient(135deg, var(--combat-primary) 0%, #991b1b 100%);color:white;padding:2rem;border-radius:16px 16px 0 0;margin:-1rem -1rem 0 -1rem}.encounter-title{font-size:2rem;font-weight:700;margin:0 0 .5rem 0;text-shadow:0 2px 4px rgba(0, 0, 0, 0.3)}.encounter-status-badge{padding:.5rem 1rem;border-radius:8px;font-weight:600;text-transform:uppercase;background:rgba(255, 255, 255, 0.2);backdrop-filter:blur(10px)}.encounter-status-badge.active{background:rgba(16, 185, 129, 0.9)}.monster-stat-block{background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);border:3px solid var(--monster-color);border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 4px 12px rgba(220, 53, 69, 0.2);transition:all .3s ease}.monster-stat-block:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(220, 53, 69, 0.3)}.monster-name{font-size:1.5rem;font-weight:700;color:var(--monster-color);margin-bottom:.5rem}.monster-type{font-size:.875rem;color:#92400e;font-style:italic;margin-bottom:1rem}.monster-stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(100px, 1fr));gap:1rem;margin-bottom:1rem}.monster-stat{text-align:center;padding:.75rem;background:white;border-radius:8px;border:2px solid #fbbf24}.monster-stat-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-bottom:.25rem}.monster-stat-value{display:block;font-size:1.5rem;font-weight:700;color:#1f2937}.combat-tracker-header{background:linear-gradient(135deg, var(--dnd-purple) 0%, #92400e 100%);color:white;padding:2rem;border-radius:16px;margin-bottom:2rem}.combat-round-display{background:rgba(255, 255, 255, 0.15);border:3px solid rgba(255, 255, 255, 0.3);border-radius:16px;padding:2rem;text-align:center;backdrop-filter:blur(10px)}.round-number{font-size:4rem;font-weight:700;line-height:1;margin-bottom:.5rem}.round-label{font-size:1rem;text-transform:uppercase;letter-spacing:.1em;opacity:.9}.initiative-tracker{background:white;border:3px solid rgba(139, 92, 246, 0.2);border-radius:16px;overflow:hidden}.initiative-header{background:linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(109, 40, 217, 0.05) 100%);padding:1.5rem;border-bottom:2px solid rgba(139, 92, 246, 0.2)}.participant-card{padding:1.5rem;border-bottom:2px solid #e5e7eb;transition:all .3s ease;position:relative}.participant-card:last-child{border-bottom:none}.participant-card.current-turn{background:linear-gradient(135deg, rgba(16, 185, 129, 0.1) 0%, rgba(5, 150, 105, 0.05) 100%);border-left:6px solid #10b981;animation:glow 2s infinite}@keyframes glow{0%,100%{box-shadow:0 0 0 rgba(16, 185, 129, 0)}50%{box-shadow:0 0 20px rgba(16, 185, 129, 0.3)}}.participant-card.monster{border-left:4px solid var(--monster-color)}.participant-card.pc{border-left:4px solid var(--pc-color)}.participant-card:hover{background:rgba(139, 92, 246, 0.03)}.initiative-badge{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg, #6b7280 0%, #4b5563 100%);color:white;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 12px rgba(0, 0, 0, 0.2)}.initiative-badge.current-turn{background:linear-gradient(135deg, #10b981 0%, #059669 100%);animation:pulse 2s infinite}@keyframes pulse{0%,100%{transform:scale(1);box-shadow:0 4px 12px rgba(16, 185, 129, 0.4)}50%{transform:scale(1.05);box-shadow:0 6px 20px rgba(16, 185, 129, 0.6)}}.hp-display{margin-bottom:1rem}.hp-bar-combat{height:30px;background:#e5e7eb;border-radius:15px;overflow:hidden;position:relative;border:2px solid #d1d5db}.hp-progress-combat{height:100%;transition:width .5s ease;display:flex;align-items:center;justify-content:center;color:white;font-weight:700;font-size:.875rem}.hp-progress-combat.healthy{background:linear-gradient(90deg, #10b981 0%, #059669 100%)}.hp-progress-combat.wounded{background:linear-gradient(90deg, #f59e0b 0%, #d97706 100%)}.hp-progress-combat.critical{background:linear-gradient(90deg, #ef4444 0%, #dc2626 100%)}.hp-text{font-size:.875rem;color:#6b7280;margin-top:.25rem}.temp-hp{color:#3b82f6;font-weight:600}.death-saves-display{background:linear-gradient(135deg, rgba(239, 68, 68, 0.1) 0%, rgba(220, 38, 38, 0.05) 100%);border:2px solid rgba(239, 68, 68, 0.3);border-radius:12px;padding:1rem;margin-top:1rem}.death-save-dots{display:flex;gap:.5rem;align-items:center}.death-save-dot{width:20px;height:20px;border-radius:50%;border:2px solid currentColor;transition:all .2s ease}.death-save-dot.filled{background:currentColor}.death-save-success .death-save-dot{color:#10b981}.death-save-failure .death-save-dot{color:#ef4444}.action-economy{background:linear-gradient(135deg, rgba(59, 130, 246, 0.1) 0%, rgba(37, 99, 235, 0.05) 100%);border:2px solid rgba(59, 130, 246, 0.3);border-radius:12px;padding:1rem;margin-top:1rem}.action-token{padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;transition:all .2s ease}.action-token.available{background:#10b981;color:white}.action-token.used{background:#9ca3af;color:white;opacity:.6}.conditions-display{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.condition-badge{padding:.5rem 1rem;border-radius:8px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#fbbf24;color:#78350f;border:2px solid #f59e0b}.participant-actions{display:flex;flex-direction:column;gap:.5rem}.combat-action-btn{padding:.5rem 1rem;border-radius:8px;font-weight:600;text-decoration:none;text-align:center;transition:all .2s ease;border:2px solid transparent}.combat-action-btn.damage{background:rgba(239, 68, 68, 0.1);color:#dc2626;border-color:rgba(239, 68, 68, 0.3)}.combat-action-btn.damage:hover{background:#ef4444;color:white}.combat-action-btn.heal{background:rgba(16, 185, 129, 0.1);color:#059669;border-color:rgba(16, 185, 129, 0.3)}.combat-action-btn.heal:hover{background:#10b981;color:white}.combat-log{background:white;border:2px solid rgba(139, 92, 246, 0.2);border-radius:16px;margin-top:2rem;overflow:hidden}.combat-log-header{background:linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(109, 40, 217, 0.05) 100%);padding:1rem 1.5rem;border-bottom:2px solid rgba(139, 92, 246, 0.2)}.combat-log-entry{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.combat-log-entry:last-child{border-bottom:none}.combat-log-entry:hover{background:rgba(139, 92, 246, 0.03)}.difficulty-badge{padding:.5rem 1rem;border-radius:8px;font-weight:600;text-transform:uppercase;font-size:.875rem}.difficulty-badge.easy{background:rgba(16, 185, 129, 0.2);color:#065f46;border:2px solid #10b981}.difficulty-badge.medium{background:rgba(251, 191, 36, 0.2);color:#92400e;border:2px solid #fbbf24}.difficulty-badge.hard{background:rgba(239, 68, 68, 0.2);color:#991b1b;border:2px solid #ef4444}.difficulty-badge.deadly{background:rgba(88, 28, 135, 0.2);color:#581c87;border:2px solid #a855f7}.encounter-summary{background:linear-gradient(135deg, rgba(139, 92, 246, 0.1) 0%, rgba(109, 40, 217, 0.05) 100%);border:2px solid rgba(139, 92, 246, 0.2);border-radius:12px;padding:1.5rem;margin-top:2rem}.summary-stat{text-align:center}.summary-stat-value{display:block;font-size:2rem;font-weight:700;color:var(--dnd-purple)}.summary-stat-label{display:block;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin-top:.25rem}.quick-actions-panel{background:white;border:2px solid rgba(139, 92, 246, 0.2);border-radius:16px;overflow:hidden}.quick-action-item{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:1rem}.quick-action-item:last-child{border-bottom:none}.quick-action-item:hover{background:rgba(139, 92, 246, 0.05);padding-left:2rem}.quick-action-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg, var(--dnd-purple) 0%, #92400e 100%);color:white;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.current-turn-banner{background:linear-gradient(90deg, #10b981 0%, #059669 100%);color:white;padding:1rem 1.5rem;margin:-1.5rem -1.5rem 1rem -1.5rem;text-align:center;font-weight:700;text-transform:uppercase;letter-spacing:.1em;box-shadow:0 4px 12px rgba(16, 185, 129, 0.3)}@media(max-width: 768px){.monster-stats-grid{grid-template-columns:repeat(2, 1fr)}.round-number{font-size:3rem}.initiative-badge{width:50px;height:50px;font-size:1.25rem}.participant-card{padding:1rem}}:root{--dnd-primary: #d97706;--dnd-primary-dark: #b45309;--dnd-primary-light: #f59e0b;--dnd-gold: #fbbf24;--dnd-gold-dark: #d97706;--dnd-gold-light: #fcd34d;--dnd-crimson: #dc2626;--dnd-emerald: #10b981;--dnd-bg-dark: #2c1810;--dnd-bg-darker: #1a0f08;--dnd-bg-card: #3d2817;--dnd-bg-hover: #4a3422;--dnd-text-light: #fef3c7;--dnd-text-muted: #d4b896;--dnd-text-gold: #fde68a;--dnd-border: rgba(217, 119, 6, 0.4);--dnd-glow: rgba(251, 191, 36, 0.3);--dnd-shadow: 0 10px 30px rgba(0, 0, 0, 0.6);--dnd-shadow-lg: 0 20px 60px rgba(0, 0, 0, 0.8)}.dashboard-container{min-height:100vh;background:linear-gradient(135deg, var(--dnd-bg-darker) 0%, var(--dnd-bg-dark) 100%);padding:2rem;position:relative;overflow:hidden}.dashboard-container::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' /%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.dashboard-content{position:relative;z-index:1;max-width:1600px;margin:0 auto}.dashboard-hero{background:linear-gradient(135deg, var(--dnd-bg-card) 0%, var(--dnd-bg-darker) 100%);border:2px solid var(--dnd-border);border-radius:16px;padding:2rem;margin-bottom:2rem;position:relative;overflow:hidden;box-shadow:var(--dnd-shadow)}.dashboard-hero::before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle, var(--dnd-glow) 0%, transparent 70%);pointer-events:none}.hero-greeting{font-size:2rem;font-weight:700;color:var(--dnd-text-light);margin-bottom:.5rem;text-shadow:0 2px 10px rgba(0, 0, 0, 0.5)}.hero-subtitle{font-size:1.125rem;color:var(--dnd-text-muted);margin-bottom:1.5rem}.hero-role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:linear-gradient(135deg, var(--dnd-primary) 0%, var(--dnd-primary-dark) 100%);color:white;border-radius:20px;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 4px 12px rgba(139, 92, 246, 0.4)}.role-dropdown-override-removed{min-width:320px;max-height:70vh;overflow-y:auto;background:var(--dnd-bg-card);border:1px solid var(--dnd-border);color:var(--dnd-text-light);padding:.625rem 1rem;border-radius:8px;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:var(--dnd-shadow)}.role-dropdown:hover{background:var(--dnd-bg-hover);box-shadow:0 0 15px var(--dnd-glow)}.role-dropdown:focus{outline:none;box-shadow:0 0 0 3px rgba(139, 92, 246, 0.3)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1.5rem;margin-bottom:2rem}.stat-widget{background:var(--dnd-bg-card);border:1px solid var(--dnd-border);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3);position:relative;overflow:hidden}.stat-widget::before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg, var(--dnd-gold) 0%, var(--dnd-gold-dark) 100%)}.stat-widget:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0, 0, 0, 0.4),0 0 20px var(--dnd-glow);border-color:var(--dnd-primary-light)}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg, var(--dnd-primary) 0%, var(--dnd-primary-dark) 100%);border-radius:12px;box-shadow:0 4px 12px rgba(139, 92, 246, 0.4)}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--dnd-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:var(--dnd-text-light);line-height:1}.dashboard-section{margin-bottom:3rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-title{font-size:1.5rem;font-weight:700;color:var(--dnd-text-light);display:flex;align-items:center;gap:.75rem}.section-title-icon{font-size:1.75rem}.section-action{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:transparent;border:1px solid var(--dnd-border);color:var(--dnd-text-muted);text-decoration:none;border-radius:8px;font-size:.875rem;transition:all .2s ease}.section-action:hover{background:var(--dnd-bg-hover);color:var(--dnd-text-light);border-color:var(--dnd-primary);box-shadow:0 0 15px var(--dnd-glow)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.5rem}.campaign-card{background:var(--dnd-bg-card);border:1px solid var(--dnd-border);border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3);position:relative}.campaign-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0, 0, 0, 0.5),0 0 25px var(--dnd-glow);border-color:var(--dnd-primary-light)}.campaign-card-image{width:100%;height:180px;background:linear-gradient(135deg, var(--dnd-primary-dark) 0%, var(--dnd-bg-darker) 100%);display:flex;align-items:center;justify-content:center;font-size:4rem;position:relative;overflow:hidden}.campaign-card-image::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center, rgba(251, 191, 36, 0.1) 0%, transparent 70%)}.campaign-card-body{padding:1.25rem}.campaign-card-title{font-size:1.25rem;font-weight:700;color:var(--dnd-text-light);margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.campaign-card-description{font-size:.875rem;color:var(--dnd-text-muted);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.campaign-card-meta{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:var(--dnd-text-muted);margin-bottom:1rem}.campaign-card-meta-item{display:flex;align-items:center;gap:.25rem}.campaign-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid var(--dnd-border)}.next-session{font-size:.8125rem;color:var(--dnd-gold);font-weight:600}.character-card{background:var(--dnd-bg-card);border:1px solid var(--dnd-border);border-radius:12px;overflow:hidden;transition:all .3s ease;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3);position:relative}.character-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0, 0, 0, 0.5),0 0 25px var(--dnd-glow);border-color:var(--dnd-primary-light)}.character-card-header{padding:1.25rem;background:linear-gradient(135deg, var(--dnd-primary-dark) 0%, var(--dnd-bg-darker) 100%);position:relative}.character-avatar{width:80px;height:80px;border-radius:50%;background:var(--dnd-bg-darker);border:3px solid var(--dnd-gold);display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin-bottom:1rem;box-shadow:0 4px 12px rgba(0, 0, 0, 0.5)}.character-name{font-size:1.25rem;font-weight:700;color:var(--dnd-text-light);margin-bottom:.25rem}.character-class-race{font-size:.875rem;color:var(--dnd-text-muted)}.character-card-body{padding:1.25rem}.character-level{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:linear-gradient(135deg, var(--dnd-gold) 0%, var(--dnd-gold-dark) 100%);color:var(--dnd-bg-darker);border-radius:20px;font-weight:700;font-size:.875rem;margin-bottom:1rem}.hp-bar-container{margin-bottom:1rem}.hp-bar-label{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--dnd-text-muted);margin-bottom:.5rem}.hp-bar{width:100%;height:12px;background:var(--dnd-bg-darker);border-radius:6px;overflow:hidden;border:1px solid var(--dnd-border)}.hp-bar-fill{height:100%;background:linear-gradient(90deg, var(--dnd-emerald) 0%, #34d399 100%);border-radius:6px;transition:width .3s ease;box-shadow:0 0 10px rgba(16, 185, 129, 0.5)}.hp-bar-fill.low{background:linear-gradient(90deg, var(--dnd-gold) 0%, var(--dnd-gold-dark) 100%);box-shadow:0 0 10px rgba(251, 191, 36, 0.5)}.hp-bar-fill.critical{background:linear-gradient(90deg, var(--dnd-crimson) 0%, #b91c1c 100%);box-shadow:0 0 10px rgba(220, 38, 38, 0.5)}.character-campaign{font-size:.8125rem;color:var(--dnd-text-muted);margin-bottom:.5rem}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));gap:1rem;margin-bottom:2rem}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:var(--dnd-bg-card);border:2px solid var(--dnd-border);border-radius:12px;text-decoration:none;color:var(--dnd-text-light);transition:all .3s ease;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3);cursor:pointer}.quick-action-btn:hover{transform:translateY(-4px);border-color:var(--dnd-gold);background:linear-gradient(135deg, var(--dnd-bg-hover) 0%, var(--dnd-bg-card) 100%);box-shadow:0 8px 24px rgba(0, 0, 0, 0.4),0 0 20px var(--dnd-glow)}.quick-action-icon{font-size:3rem;filter:drop-shadow(0 4px 8px rgba(0, 0, 0, 0.5))}.quick-action-label{font-size:.875rem;font-weight:600;text-align:center}.activity-feed{background:var(--dnd-bg-card);border:1px solid var(--dnd-border);border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px rgba(0, 0, 0, 0.3)}.activity-item{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--dnd-border);transition:all .2s ease}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:rgba(139, 92, 246, 0.05);margin:0 -0.5rem;padding:1rem .5rem;border-radius:8px}.activity-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg, var(--dnd-primary) 0%, var(--dnd-primary-dark) 100%);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;box-shadow:0 4px 12px rgba(139, 92, 246, 0.4)}.activity-content{flex:1}.activity-title{font-size:.9375rem;font-weight:600;color:var(--dnd-text-light);margin-bottom:.25rem}.activity-description{font-size:.875rem;color:var(--dnd-text-muted);margin-bottom:.25rem}.activity-time{font-size:.8125rem;color:var(--dnd-text-muted);opacity:.7}.activity-empty{text-align:center;padding:3rem 1rem;color:var(--dnd-text-muted)}.activity-empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.countdown-widget{background:linear-gradient(135deg, var(--dnd-primary-dark) 0%, var(--dnd-bg-darker) 100%);border:2px solid var(--dnd-gold);border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 8px 24px rgba(0, 0, 0, 0.4),0 0 30px var(--dnd-glow);margin-bottom:2rem}.countdown-label{font-size:.875rem;color:var(--dnd-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.countdown-value{font-size:2.5rem;font-weight:700;color:var(--dnd-gold);margin-bottom:.5rem;text-shadow:0 0 20px rgba(251, 191, 36, 0.5)}.countdown-subtitle{font-size:.9375rem;color:var(--dnd-text-light)}@media(max-width: 768px){.dashboard-container{padding:1rem}.dashboard-hero{padding:1.5rem}.hero-greeting{font-size:1.5rem}.hero-subtitle{font-size:1rem}.role-switcher{position:static;margin-top:1rem}.stats-grid{grid-template-columns:repeat(2, 1fr);gap:1rem}.card-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2, 1fr)}.section-header{flex-direction:column;align-items:flex-start;gap:1rem}}@media(max-width: 480px){.stats-grid{grid-template-columns:1fr}.quick-actions{grid-template-columns:1fr}}.text-gold{color:var(--dnd-gold)}.text-crimson{color:var(--dnd-crimson)}.text-emerald{color:var(--dnd-emerald)}.badge-dnd{display:inline-flex;align-items:center;padding:.25rem .75rem;background:rgba(139, 92, 246, 0.2);border:1px solid var(--dnd-primary);color:var(--dnd-primary-light);border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.btn-dnd-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg, var(--dnd-gold) 0%, var(--dnd-gold-dark) 100%);color:var(--dnd-bg-darker);border:none;border-radius:8px;font-weight:700;font-size:.9375rem;text-decoration:none;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(251, 191, 36, 0.4)}.btn-dnd-primary:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(251, 191, 36, 0.6);background:linear-gradient(135deg, var(--dnd-gold-light) 0%, var(--dnd-gold) 100%)}.btn-dnd-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;color:var(--dnd-text-light);border:2px solid var(--dnd-border);border-radius:8px;font-weight:600;font-size:.9375rem;text-decoration:none;cursor:pointer;transition:all .3s ease}.btn-dnd-secondary:hover{border-color:var(--dnd-primary);background:rgba(139, 92, 246, 0.1);box-shadow:0 0 20px var(--dnd-glow)}@media(prefers-color-scheme: light){:root{--dnd-primary: #b45309;--dnd-primary-dark: #92400e;--dnd-primary-light: #d97706;--dnd-gold: #ca8a04;--dnd-gold-dark: #a16207;--dnd-gold-light: #eab308;--dnd-crimson: #b91c1c;--dnd-emerald: #047857;--dnd-bg-dark: #fefce8;--dnd-bg-darker: #ffffff;--dnd-bg-card: #fef3c7;--dnd-bg-hover: #fef08a;--dnd-text-light: #f5f5f4;--dnd-text-muted: #44403c;--dnd-text-gold: #92400e;--dnd-border: rgba(180, 83, 9, 0.3);--dnd-glow: rgba(202, 138, 4, 0.2);--dnd-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);--dnd-shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.15)}.dashboard-container{background:linear-gradient(135deg, #fefce8 0%, #fffbeb 100%)}.dashboard-hero{background:linear-gradient(135deg, #fef3c7 0%, #fefce8 100%);border-color:var(--dnd-border)}.dashboard-hero::before{background:radial-gradient(circle, rgba(202, 138, 4, 0.08) 0%, transparent 70%)}.hero-greeting,.section-title,.activity-title{color:var(--dnd-text-light) !important}.hero-subtitle,.activity-description,.stat-label{color:var(--dnd-text-muted) !important}.stat-widget,.quick-action-button,.campaign-card,.activity-item{background:linear-gradient(135deg, #ffffff 0%, #fef3c7 100%);border-color:var(--dnd-border);color:var(--dnd-text-light) !important}.stat-widget:hover,.quick-action-button:hover,.campaign-card:hover{background:linear-gradient(135deg, #fef3c7 0%, #fef08a 100%);border-color:var(--dnd-primary)}.stat-value{color:var(--dnd-primary) !important}.hero-role-badge{background:var(--dnd-primary);color:#fff}.activity-icon{background:var(--dnd-bg-hover);color:var(--dnd-primary)}.activity-time{color:var(--dnd-text-muted)}.countdown-widget{background:linear-gradient(135deg, #fef3c7 0%, #fefce8 100%);border-color:var(--dnd-gold)}.countdown-value{color:var(--dnd-primary)}.countdown-label,.countdown-subtitle{color:var(--dnd-text-muted)}.btn-dnd-primary{background:var(--dnd-primary);color:#fff;border-color:var(--dnd-primary)}.btn-dnd-primary:hover{background:var(--dnd-primary-dark);border-color:var(--dnd-primary-dark)}.btn-dnd-secondary{background:transparent;color:var(--dnd-primary);border-color:var(--dnd-border)}.btn-dnd-secondary:hover{background:var(--dnd-bg-hover);border-color:var(--dnd-primary)}.activity-empty{background:var(--dnd-bg-card);border-color:var(--dnd-border);color:var(--dnd-text-muted)}.activity-empty-icon{color:var(--dnd-text-muted)}.role-dropdown{background:#fff;color:var(--dnd-text-light);border-color:var(--dnd-border)}.role-dropdown:hover,.role-dropdown:focus{background:var(--dnd-bg-hover);border-color:var(--dnd-primary)}.section-header{border-bottom:2px solid var(--dnd-border)}.section-action{color:var(--dnd-primary) !important}.section-action:hover{color:var(--dnd-primary-dark) !important}.card-grid>*{background:linear-gradient(135deg, #ffffff 0%, #fef3c7 100%);border-color:var(--dnd-border)}.dashboard-container *:not(.btn):not(.badge){color:inherit}}.modal{border:none;border-radius:8px;padding:0;max-width:600px;max-height:80vh;box-shadow:0 20px 60px rgba(0, 0, 0, 0.3)}.modal::backdrop{background:rgba(0, 0, 0, 0.5);backdrop-filter:blur(4px)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:1.25rem}.modal-header button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1;opacity:.6}.modal-header button:hover{opacity:1}.modal-body{padding:1.5rem}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.75rem;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:white;border-radius:8px;box-shadow:0 4px 12px rgba(0, 0, 0, 0.15);pointer-events:auto;min-width:300px;max-width:500px}.toast-success{border-left:4px solid #22c55e}.toast-error{border-left:4px solid #ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-info{border-left:4px solid #3b82f6}.toast-content{display:flex;align-items:center;gap:.5rem;flex:1}.toast-icon{font-size:1.25rem}.toast-close{background:none;border:none;font-size:1.25rem;cursor:pointer;opacity:.6;padding:.25rem;line-height:1}.toast-close:hover{opacity:1}.dropdown{position:relative}.dropdown-menu{position:fixed;background:white;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px rgba(0, 0, 0, 0.1);padding:.5rem 0;min-width:200px;z-index:1000}.dropdown-menu [role=menuitem]{display:block;padding:.75rem 1rem;color:inherit;text-decoration:none;cursor:pointer;transition:background .15s}.dropdown-menu [role=menuitem]:hover,.dropdown-menu [role=menuitem]:focus{background:#f5f5f5;outline:none}[role=tablist]{display:flex;border-bottom:2px solid #e0e0e0;gap:.5rem}[role=tab]{padding:.75rem 1.5rem;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:1rem;transition:all .2s}[role=tab]:hover{background:#f5f5f5}[role=tab][aria-selected=true]{border-bottom-color:#3b82f6;color:#3b82f6;font-weight:600}[role=tabpanel]{padding:1.5rem}.accordion-item{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:.5rem}.accordion-item button[data-accordion-target=trigger]{width:100%;padding:1rem 1.5rem;background:white;border:none;text-align:left;font-size:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.accordion-item button[data-accordion-target=trigger]:hover{background:#f9fafb}.accordion-item [data-accordion-target=panel]{padding:0 1.5rem 1rem 1.5rem}.combobox [role=combobox]{width:100%;padding:.5rem 1rem;border:1px solid #d0d0d0;border-radius:4px}.combobox [role=combobox]:focus{outline:2px solid #3b82f6;outline-offset:2px}.combobox [role=listbox]{position:absolute;background:white;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 12px rgba(0, 0, 0, 0.1);max-height:300px;overflow-y:auto;z-index:1000;margin-top:.25rem;list-style:none;padding:0}.combobox [role=option]{padding:.75rem 1rem;cursor:pointer;transition:background .15s}.combobox [role=option]:hover,.combobox [role=option].selected{background:#f5f5f5}.combobox [role=option][aria-selected=true]{background:#eff6ff;color:#3b82f6}.combobox-error{padding:1rem;color:#ef4444}.carousel{position:relative;overflow:hidden}.carousel-slides{position:relative;display:flex;width:100%}.carousel-slide{flex:0 0 100%;display:none}.carousel-slide.active{display:block}.carousel button{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255, 255, 255, 0.9);border:none;padding:.75rem 1rem;font-size:1.5rem;cursor:pointer;z-index:10;border-radius:4px}.carousel button:first-of-type{left:1rem}.carousel button:nth-of-type(2){right:1rem}.carousel button:hover{background:white}.infinite-scroll-item{padding:1rem;border-bottom:1px solid #e0e0e0}.infinite-scroll-item:last-child{border-bottom:none}.infinite-scroll-sentinel{height:1px}.infinite-scroll-loading{padding:2rem;text-align:center;color:#666}[draggable=true]{cursor:move;user-select:none}[draggable=true].dragging{opacity:.5;transform:scale(0.95)}[draggable=true].selected{outline:2px solid #3b82f6;outline-offset:2px}[data-drag-drop-target=dropZone]{min-height:100px;padding:1rem;border:2px dashed #e0e0e0;border-radius:8px;transition:all .2s}[data-drag-drop-target=dropZone].drop-zone-active{border-color:#3b82f6;background:#f0f9ff}[data-drag-drop-target=dropZone].drag-over{border-color:#10b981;background:#ecfdf5}.tooltip{position:fixed;background:#1f2937;color:white;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;line-height:1.25rem;max-width:250px;word-wrap:break-word;z-index:10000;pointer-events:none}.tooltip-arrow{position:absolute;width:0;height:0;border:4px solid transparent}.tooltip-top .tooltip-arrow{bottom:-8px;left:50%;transform:translateX(-50%);border-top-color:#1f2937}.tooltip-bottom .tooltip-arrow{top:-8px;left:50%;transform:translateX(-50%);border-bottom-color:#1f2937}.tooltip-left .tooltip-arrow{right:-8px;top:50%;transform:translateY(-50%);border-left-color:#1f2937}.tooltip-right .tooltip-arrow{left:-8px;top:50%;transform:translateY(-50%);border-right-color:#1f2937}@media(prefers-reduced-motion: reduce){.toast,.modal,.dropdown-menu,[role=tabpanel],[data-accordion-target=panel]{transition:none !important;animation:none !important}}:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@media(prefers-contrast: high){.toast,.modal,.dropdown-menu,.combobox [role=listbox]{border-width:2px}}.form-page-container{max-width:900px;margin:2rem auto;padding:0 1.5rem;min-height:calc(100vh - 200px);position:relative}.glassmorphic-form-card{background:rgba(255, 255, 255, 0.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--auth-radius-lg);border:1px solid rgba(255, 255, 255, 0.5);box-shadow:0 8px 32px rgba(0, 0, 0, 0.08),0 2px 8px rgba(0, 0, 0, 0.04);overflow:hidden;animation:cardFadeIn .6s ease;position:relative}@keyframes cardFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.glassmorphic-form-card:hover{box-shadow:0 12px 48px rgba(102, 126, 234, 0.12),0 4px 12px rgba(0, 0, 0, 0.08);border-color:rgba(102, 126, 234, 0.2);transition:all var(--auth-transition-base)}.glassmorphic-form-header{background:linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.08));border-bottom:1px solid rgba(102, 126, 234, 0.15);padding:2rem;position:relative;overflow:hidden}.glassmorphic-form-header::before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle, rgba(255, 255, 255, 0.05) 1px, transparent 1px);background-size:30px 30px;animation:particleFloat 20s linear infinite;pointer-events:none}@keyframes particleFloat{from{transform:translate(0, 0)}to{transform:translate(30px, 30px)}}.glassmorphic-form-header h1{margin:0;font-size:2rem;font-weight:700;background:linear-gradient(135deg, var(--auth-primary), var(--auth-bg-gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1;display:flex;align-items:center;gap:.75rem}.form-header-icon{font-size:1.75rem;filter:drop-shadow(0 2px 8px rgba(102, 126, 234, 0.3))}.glassmorphic-form-body{padding:2.5rem}.form-fields-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:1.5rem;margin-bottom:2rem}.form-group{position:relative;display:flex;flex-direction:column;gap:var(--auth-spacing-xs);animation:slideInUp .3s ease}@keyframes slideInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-group-full{grid-column:1/-1}.form-group label{font-size:.875rem;font-weight:600;color:var(--auth-text-primary);display:flex;align-items:center;gap:var(--auth-spacing-xs);letter-spacing:.01em;text-transform:uppercase;font-size:.8125rem;opacity:.9}.form-group label .required{color:var(--auth-error);font-weight:700}.form-group label .label-icon{font-size:1em;opacity:.7}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;width:20px;height:20px;color:var(--auth-text-secondary);pointer-events:none;transition:all var(--auth-transition-fast);z-index:1}.form-control{width:100%;padding:.875rem 1rem;font-size:1rem;color:var(--auth-text-primary);background:var(--auth-input-bg);border:2px solid var(--auth-input-border);border-radius:var(--auth-radius-md);transition:all var(--auth-transition-fast);outline:none;font-family:inherit}.input-wrapper .form-control{padding-left:3rem}.form-control:hover:not(:focus):not(:disabled){border-color:rgba(102, 126, 234, 0.3);background:rgba(255, 255, 255, 0.95)}.form-control:focus{border-color:var(--auth-input-focus);box-shadow:0 0 0 3px rgba(102, 126, 234, 0.1);background:#fff;transform:translateY(-1px)}.form-control:focus+.input-icon{color:var(--auth-input-focus);transform:scale(1.1)}textarea.form-control{min-height:120px;resize:vertical;line-height:1.6;padding-top:1rem}select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%23667eea' d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:16px;padding-right:3rem;cursor:pointer}select.form-control:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Cpath fill='%23667eea' d='M8 5l5 5H3z'/%3E%3C/svg%3E")}input[type=checkbox].form-control{width:22px;height:22px;cursor:pointer;accent-color:var(--auth-primary);border-radius:var(--auth-radius-sm);padding:0}.checkbox-wrapper{display:flex;align-items:center;gap:.75rem;padding:.5rem 0}input[type=number].form-control,input[type=date].form-control,input[type=datetime-local].form-control{cursor:pointer}.form-control:disabled{background:rgba(241, 245, 249, 0.6);border-color:#e2e8f0;cursor:not-allowed;opacity:.7}.form-control.is-valid{border-color:var(--auth-success);padding-right:calc(1.5em + .75rem);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%2310B981' viewBox='0 0 16 16'%3E%3Cpath d='M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right calc(.375em + .1875rem) center;background-size:calc(.75em + .375rem);animation:validPulse .3s ease}.form-control.is-valid:focus{border-color:var(--auth-success);box-shadow:0 0 0 3px rgba(16, 185, 129, 0.1)}@keyframes validPulse{0%{transform:scale(1)}50%{transform:scale(1.01)}100%{transform:scale(1)}}.form-control.is-invalid,.form-control.error{border-color:var(--auth-error);animation:shake .4s ease}.form-control.is-invalid:focus,.form-control.error:focus{border-color:var(--auth-error);box-shadow:0 0 0 3px rgba(239, 68, 68, 0.1)}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.field-error{font-size:.8125rem;color:var(--auth-error);display:flex;align-items:center;gap:.375rem;margin-top:.375rem;animation:slideInUp .3s ease}.field-error::before{content:"⚠";font-size:1em}.form-errors-summary{margin-bottom:2rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);border:2px solid var(--auth-error);border-radius:var(--auth-radius-md);animation:slideInDown .4s ease;box-shadow:0 4px 12px rgba(239, 68, 68, 0.15)}@keyframes slideInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.form-errors-summary h6{margin:0 0 .75rem 0;font-weight:700;color:#991b1b;font-size:1rem;display:flex;align-items:center;gap:.5rem}.form-errors-summary h6::before{content:"⚠";font-size:1.25em}.form-errors-summary ul{margin:0;padding-left:1.5rem;list-style:none}.form-errors-summary ul li{position:relative;margin-bottom:.5rem;color:#991b1b;font-size:.9375rem;font-weight:500;padding-left:1rem}.form-errors-summary ul li::before{content:"→";position:absolute;left:0;font-weight:700;color:var(--auth-error)}.form-errors-summary ul li:last-child{margin-bottom:0}.glassmorphic-form-footer{border-top:1px solid rgba(102, 126, 234, 0.1);padding:1.75rem 2.5rem;background:linear-gradient(135deg, rgba(102, 126, 234, 0.02), rgba(118, 75, 162, 0.02));display:flex;gap:1rem;justify-content:flex-end;align-items:center}.btn{padding:.875rem 1.75rem;font-size:1rem;font-weight:600;border-radius:var(--auth-radius-md);border:none;cursor:pointer;transition:all var(--auth-transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:var(--auth-spacing-xs);text-decoration:none;position:relative;overflow:hidden;min-width:120px}.btn-primary{background:linear-gradient(135deg, var(--auth-primary), var(--auth-primary-hover));color:white;box-shadow:0 4px 12px rgba(102, 126, 234, 0.3);border:2px solid transparent}.btn-primary::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);transition:left .5s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102, 126, 234, 0.4)}.btn-primary:hover::before{left:100%}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:white;color:var(--auth-text-primary);border:2px solid var(--auth-input-border);box-shadow:0 2px 8px rgba(0, 0, 0, 0.05)}.btn-secondary:hover{background:rgba(102, 126, 234, 0.05);border-color:var(--auth-primary);color:var(--auth-primary);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0, 0, 0, 0.1)}.btn-outline{background:transparent;color:var(--auth-primary);border:2px solid var(--auth-primary);box-shadow:none}.btn-outline:hover{background:var(--auth-primary);color:white;transform:translateY(-2px);box-shadow:0 4px 12px rgba(102, 126, 234, 0.3)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none !important}.btn.loading{pointer-events:none;position:relative}.btn.loading::after{content:"";position:absolute;width:16px;height:16px;border:2px solid rgba(255, 255, 255, 0.3);border-top-color:white;border-radius:50%;animation:btnSpin .6s linear infinite}@keyframes btnSpin{to{transform:rotate(360deg)}}.field-hint{display:flex;align-items:flex-start;gap:.5rem;margin-top:.5rem;padding:.75rem;background:rgba(59, 130, 246, 0.05);border-left:3px solid var(--auth-primary);border-radius:var(--auth-radius-sm);font-size:.8125rem;color:#1e40af;line-height:1.5}.field-hint::before{content:"ℹ";font-size:1.1em;color:var(--auth-primary);font-weight:700;flex-shrink:0}.form-success-message{margin-bottom:2rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);border:2px solid var(--auth-success);border-radius:var(--auth-radius-md);color:#065f46;font-weight:600;display:flex;align-items:center;gap:.75rem;animation:slideInDown .4s ease;box-shadow:0 4px 12px rgba(16, 185, 129, 0.15)}.form-success-message::before{content:"✓";font-size:1.5em;color:var(--auth-success);font-weight:700}@media(max-width: 768px){.form-page-container{padding:0 1rem;margin:1rem auto}.glassmorphic-form-header{padding:1.5rem}.glassmorphic-form-header h1{font-size:1.5rem}.glassmorphic-form-body{padding:1.5rem}.form-fields-grid{grid-template-columns:1fr;gap:1.25rem}.glassmorphic-form-footer{padding:1.25rem 1.5rem;flex-direction:column-reverse}.btn{width:100%;min-width:unset}textarea.form-control{min-height:100px}}@media(max-width: 480px){.glassmorphic-form-header h1{font-size:1.25rem}.form-control{font-size:.9375rem}.btn{padding:.75rem 1.5rem;font-size:.9375rem}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}*:focus-visible{outline:3px solid var(--auth-primary);outline-offset:2px}@media(prefers-contrast: high){.glassmorphic-form-card{border-width:2px;border-color:var(--auth-primary)}.form-control{border-width:2px}.btn{border-width:2px}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}@media print{.glassmorphic-form-footer,.btn{display:none}.glassmorphic-form-card{box-shadow:none;border:1px solid #000;background:white}.form-control{border:1px solid #000}}.growth-analysis-dashboard{min-height:100vh;background:linear-gradient(135deg, #f5f7fa 0%, #e9ecef 100%)}.analysis-header{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);color:white;padding:3rem 0;box-shadow:0 4px 6px rgba(0, 0, 0, 0.1);position:relative;overflow:hidden}.analysis-header::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0 L50 10 L60 30 L50 50 L30 60 L10 50 L0 30 L10 10 Z' fill='%23ffffff' fill-opacity='0.05'/%3E%3C/svg%3E");background-size:60px 60px;opacity:.2}.analysis-header .container{position:relative;z-index:1}.analysis-header h1{font-weight:700;text-shadow:2px 2px 4px rgba(0, 0, 0, 0.2)}.analysis-header .lead{color:rgba(255, 255, 255, 0.9)}.section-title{font-size:1.75rem;font-weight:600;border-left:4px solid var(--bs-primary);padding-left:1rem;margin-bottom:1.5rem}.overview-section .stat-card{text-align:center;padding:1rem;border-radius:.5rem;background:linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);border:2px solid transparent;transition:all .3s ease}.overview-section .stat-card:hover{border-color:var(--bs-primary);transform:translateY(-4px);box-shadow:0 8px 16px rgba(0, 0, 0, 0.1)}.overview-section .stat-card label{display:block;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.overview-section .stat-card .h3,.overview-section .stat-card .h5{color:var(--bs-dark);margin-bottom:0}.strength-card{transition:all .3s ease;position:relative;overflow:hidden}.strength-card::before{content:"";font-family:"Font Awesome 5 Free";font-weight:900;position:absolute;top:-20px;right:-20px;font-size:120px;color:rgba(40, 167, 69, 0.05);pointer-events:none}.strength-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(40, 167, 69, 0.15);border-color:var(--bs-success) !important}.strength-card .card-title{color:var(--bs-success)}.strength-card .badge.bg-danger{animation:pulse-danger 2s ease-in-out infinite}@keyframes pulse-danger{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.weakness-card{transition:all .3s ease;position:relative;overflow:hidden}.weakness-card::before{content:"";font-family:"Font Awesome 5 Free";font-weight:900;position:absolute;top:-20px;right:-20px;font-size:120px;color:rgba(255, 193, 7, 0.05);pointer-events:none}.weakness-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(255, 193, 7, 0.15);border-color:var(--bs-warning) !important}.weakness-card .card-title{color:var(--bs-warning)}.recommendation-box{border-left:3px solid var(--bs-primary);background:linear-gradient(to right, rgba(13, 110, 253, 0.05), transparent)}.weakness-card .badge.bg-danger{animation:pulse-danger 2s ease-in-out infinite}.suggestion-card{transition:all .3s ease;border-radius:.5rem;overflow:hidden}.suggestion-card:hover{box-shadow:0 8px 16px rgba(0, 0, 0, 0.1)}.suggestion-card .accordion-button{font-size:1.1rem;font-weight:600;padding:1rem 1.5rem;background:linear-gradient(to right, #f8f9fa, #fff)}.suggestion-card .accordion-button:not(.collapsed){background:linear-gradient(to right, #e7f3ff, #fff);color:var(--bs-primary);box-shadow:inset 0 -1px 0 rgba(0, 0, 0, 0.125)}.suggestion-card .accordion-button:focus{box-shadow:0 0 0 .25rem rgba(13, 110, 253, 0.25);border-color:var(--bs-primary)}.suggestion-card .badge.bg-danger{animation:pulse-danger 2s ease-in-out infinite}.impact-box{border-left:3px solid var(--bs-success)}.d20-explanation{border-left:3px solid var(--bs-primary);position:relative}.d20-explanation::before{content:"";font-family:"Font Awesome 5 Free";font-weight:900;position:absolute;top:-10px;right:-10px;font-size:60px;color:rgba(13, 110, 253, 0.1);pointer-events:none}.suggestion-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}.suggestion-actions .btn:focus{box-shadow:0 0 0 .25rem rgba(13, 110, 253, 0.25)}.feat-impact,.feat-equivalent{border-radius:.375rem;transition:all .2s ease}.feat-impact:hover,.feat-equivalent:hover{transform:translateX(4px)}.example-box{font-style:italic;border-left:3px solid var(--bs-info)}.progression-section .progress{border-radius:1rem;overflow:hidden;background:#e9ecef;box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1)}.progression-section .progress-bar{background:linear-gradient(90deg, #28a745 0%, #20c997 100%);font-weight:600;font-size:1rem;text-shadow:1px 1px 2px rgba(0, 0, 0, 0.2);transition:width .6s ease}.benchmark-card{transition:all .3s ease;border:2px solid transparent}.benchmark-card:hover{background:white !important;border-color:var(--bs-primary);transform:translateY(-4px);box-shadow:0 8px 16px rgba(0, 0, 0, 0.1)}.modal-xl{max-width:1200px}.analysis-loading{min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.analysis-loading .spinner-border{border-width:.35em}.analysis-loading h4{font-weight:600;color:var(--bs-primary)}.analysis-loading .progress{border-radius:1rem;overflow:hidden;background:#e9ecef;box-shadow:inset 0 1px 2px rgba(0, 0, 0, 0.1)}.analysis-results{max-height:calc(100vh - 300px);overflow-y:auto;padding:1rem}.d20-pattern{background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 0 L50 10 L60 30 L50 50 L30 60 L10 50 L0 30 L10 10 Z' fill='%23000000' fill-opacity='0.03'/%3E%3C/svg%3E");background-size:60px 60px}.critical-success{background:linear-gradient(135deg, #28a745 0%, #20c997 100%);color:white;padding:.5rem 1rem;border-radius:.5rem;box-shadow:0 4px 8px rgba(40, 167, 69, 0.3)}.critical-failure{background:linear-gradient(135deg, #dc3545 0%, #c82333 100%);color:white;padding:.5rem 1rem;border-radius:.5rem;box-shadow:0 4px 8px rgba(220, 53, 69, 0.3)}@keyframes fade-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .5s ease forwards}@keyframes slide-in-right{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.animate-slide-in-right{animation:slide-in-right .5s ease forwards}@keyframes pulse-glow{0%,100%{box-shadow:0 0 5px rgba(13, 110, 253, 0.5)}50%{box-shadow:0 0 20px rgba(13, 110, 253, 0.8)}}.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}@media(prefers-contrast: high){.strength-card,.weakness-card,.suggestion-card{border-width:3px !important}.badge{border:2px solid currentColor}.recommendation-box,.d20-explanation,.impact-box{border-left-width:5px}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}.strength-card:hover,.weakness-card:hover,.suggestion-card:hover,.benchmark-card:hover{transform:none !important}}.suggestion-actions .btn:focus-visible,.accordion-button:focus-visible{outline:3px solid var(--bs-primary);outline-offset:2px;box-shadow:0 0 0 .25rem rgba(13, 110, 253, 0.25)}.sr-only-focusable:not(:focus):not(:focus-within){position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;white-space:nowrap !important;border:0 !important}@media print{.growth-analysis-dashboard{background:white !important}.analysis-header{background:white !important;color:black !important;border-bottom:3px solid #000}.analysis-header::before{display:none}.strength-card,.weakness-card,.suggestion-card{page-break-inside:avoid;break-inside:avoid;border:2px solid #000 !important;box-shadow:none !important}.strength-card::before,.weakness-card::before{display:none}.accordion-button::after{display:none}.accordion-collapse{display:block !important;height:auto !important}.suggestion-actions{display:none}.modal{display:block;position:static}.modal-dialog{max-width:100%;margin:0}.modal-content{border:none;box-shadow:none}.modal-header,.modal-footer{display:none}}@media(max-width: 768px){.analysis-header{padding:2rem 0}.analysis-header h1{font-size:1.75rem}.section-title{font-size:1.5rem}.strength-card,.weakness-card{margin-bottom:1rem}.suggestion-actions{flex-direction:column}.suggestion-actions .btn{width:100%}.benchmark-card{margin-bottom:.5rem}}@media(max-width: 576px){.analysis-header h1{font-size:1.5rem}.section-title{font-size:1.25rem}.overview-section .stat-card{padding:.75rem}.overview-section .stat-card .h3{font-size:1.5rem}.accordion-button{font-size:1rem;padding:.75rem 1rem}}@media(prefers-color-scheme: dark){.growth-analysis-dashboard{background:linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);color:#e9ecef}.overview-section .stat-card{background:linear-gradient(135deg, #2d3748 0%, #1a202c 100%);color:#e9ecef}.strength-card,.weakness-card,.suggestion-card{background:#2d3748;border-color:#4a5568 !important;color:#e9ecef}.card-text.text-muted{color:#cbd5e0 !important}.recommendation-box,.impact-box,.d20-explanation,.example-box{background:rgba(66, 153, 225, 0.1) !important}.benchmark-card{background:#2d3748 !important;color:#e9ecef}.benchmark-card:hover{background:#374151 !important}}.glassmorphic-page-container{max-width:1400px;margin:0 auto;padding:2rem 1.5rem;min-height:calc(100vh - 200px);position:relative;z-index:1}.glassmorphic-content-card{background:rgba(255, 255, 255, 0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--auth-radius-lg, 1rem);border:1px solid rgba(255, 255, 255, 0.5);box-shadow:0 8px 32px rgba(0, 0, 0, 0.08),0 2px 8px rgba(0, 0, 0, 0.04);overflow:hidden;animation:cardFadeIn .6s ease}@keyframes cardFadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.glassmorphic-content-card:hover{box-shadow:0 12px 48px rgba(102, 126, 234, 0.12),0 4px 12px rgba(0, 0, 0, 0.08);border-color:rgba(102, 126, 234, 0.2);transition:all .2s ease}.glassmorphic-page-header{background:linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.08));border-bottom:1px solid rgba(102, 126, 234, 0.15);padding:2rem;position:relative;overflow:hidden}.glassmorphic-page-header::before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle, rgba(255, 255, 255, 0.05) 1px, transparent 1px);background-size:30px 30px;animation:particleFloat 20s linear infinite;pointer-events:none}@keyframes particleFloat{from{transform:translate(0, 0)}to{transform:translate(30px, 30px)}}.glassmorphic-page-header h1{margin:0 0 .5rem 0;font-size:2rem;font-weight:700;background:linear-gradient(135deg, #667eea, #764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1;display:flex;align-items:center;gap:.75rem}.page-icon{font-size:1.75rem;filter:drop-shadow(0 2px 8px rgba(102, 126, 234, 0.3))}.page-subtitle{color:var(--auth-text-secondary, #718096);font-size:1rem;margin:0;position:relative;z-index:1}.filters-section{padding:2rem;background:rgba(255, 255, 255, 0.5);border-bottom:1px solid rgba(102, 126, 234, 0.1)}.filters-container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.filters-left{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;flex:1}.filters-right{display:flex;gap:.75rem;align-items:center}.stats-grid-enhanced{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:1.5rem;padding:2rem;background:rgba(255, 255, 255, 0.3);border-bottom:1px solid rgba(102, 126, 234, 0.1)}.stat-card-gradient{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);border-radius:var(--auth-radius-md, 0.5rem);padding:1.5rem;color:white;position:relative;overflow:hidden;transition:all .3s ease;animation:slideInUp .4s ease;box-shadow:0 4px 12px rgba(102, 126, 234, 0.25)}@keyframes slideInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.stat-card-gradient:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(102, 126, 234, 0.35)}.stat-card-gradient::before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);animation:shimmer 3s ease-in-out infinite;pointer-events:none}@keyframes shimmer{0%,100%{transform:translate(0, 0)}50%{transform:translate(-20px, -20px)}}.gradient-purple{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%)}.gradient-blue{background:linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)}.gradient-cyan{background:linear-gradient(135deg, #43e97b 0%, #38f9d7 100%)}.gradient-pink{background:linear-gradient(135deg, #f093fb 0%, #f5576c 100%)}.gradient-orange{background:linear-gradient(135deg, #fa709a 0%, #fee140 100%)}.stat-card-content{position:relative;z-index:1;display:flex;align-items:center;gap:1.25rem}.stat-icon{font-size:2.5rem;opacity:.9;filter:drop-shadow(0 2px 8px rgba(0, 0, 0, 0.1))}.stat-details{flex:1}.stat-value{font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;opacity:.9;font-weight:500;margin-bottom:.5rem}.stat-change{font-size:.8125rem;opacity:.85;display:flex;align-items:center;gap:.25rem}.stat-change.positive::before{content:"↗";font-weight:700}.stat-change.negative::before{content:"↘";font-weight:700}.stat-change.neutral::before{content:"→";font-weight:700}.table-container{padding:2rem}.table-wrapper{background:rgba(255, 255, 255, 0.7);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--auth-radius-md, 0.5rem);border:1px solid rgba(102, 126, 234, 0.1);overflow:hidden;box-shadow:0 2px 8px rgba(0, 0, 0, 0.04)}.table-wrapper table{margin:0;background:transparent}.table-wrapper thead{background:linear-gradient(135deg, rgba(102, 126, 234, 0.08), rgba(118, 75, 162, 0.08));border-bottom:2px solid rgba(102, 126, 234, 0.2)}.table-wrapper thead th{font-weight:600;color:#667eea;text-transform:uppercase;font-size:.8125rem;letter-spacing:.05em;padding:1rem;border:none}.table-wrapper tbody tr{border-bottom:1px solid rgba(102, 126, 234, 0.08);transition:all .2s ease}.table-wrapper tbody tr:hover{background:rgba(102, 126, 234, 0.05)}.table-wrapper tbody td{padding:1rem;vertical-align:middle;border:none}.bulk-actions-bar{margin-bottom:1.5rem;padding:1rem 1.5rem;background:linear-gradient(135deg, rgba(102, 126, 234, 0.1), rgba(118, 75, 162, 0.1));backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--auth-radius-md, 0.5rem);border:1px solid rgba(102, 126, 234, 0.2);display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px rgba(102, 126, 234, 0.15)}.bulk-selection-info{font-weight:600;color:#667eea;display:flex;align-items:center;gap:.5rem}.selection-count{background:#667eea;color:white;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem}.glassmorphic-section{background:rgba(255, 255, 255, 0.7);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:var(--auth-radius-md, 0.5rem);border:1px solid rgba(102, 126, 234, 0.15);overflow:hidden;margin-bottom:1.5rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.04);transition:all .3s ease}.glassmorphic-section:hover{box-shadow:0 4px 12px rgba(102, 126, 234, 0.1);border-color:rgba(102, 126, 234, 0.25)}.section-header{background:linear-gradient(135deg, rgba(102, 126, 234, 0.06), rgba(118, 75, 162, 0.06));border-bottom:1px solid rgba(102, 126, 234, 0.15);padding:1.25rem 1.5rem}.section-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#667eea;display:flex;align-items:center;gap:.5rem}.section-body{padding:1.5rem}.section-footer{background:rgba(102, 126, 234, 0.03);border-top:1px solid rgba(102, 126, 234, 0.1);padding:1rem 1.5rem;text-align:center}.section-link{color:#667eea;text-decoration:none;font-weight:600;font-size:.9375rem;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem}.section-link:hover{color:#5a67d8;transform:translateX(4px)}.admin-sections-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(350px, 1fr));gap:1.5rem;padding:2rem}.activity-list{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:rgba(255, 255, 255, 0.5);border-radius:var(--auth-radius-sm, 0.375rem);border:1px solid rgba(102, 126, 234, 0.1);transition:all .2s ease}.activity-item:hover{background:rgba(102, 126, 234, 0.05);border-color:rgba(102, 126, 234, 0.2);transform:translateX(4px)}.activity-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg, #667eea, #764ba2);color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.activity-icon{width:40px;height:40px;border-radius:50%;background:rgba(102, 126, 234, 0.1);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.activity-details{flex:1;min-width:0}.activity-title{font-weight:600;color:var(--auth-text-primary, #1a202c);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{font-size:.8125rem;color:var(--auth-text-secondary, #718096);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.activity-time{font-size:.75rem;color:var(--auth-text-secondary, #718096);white-space:nowrap;flex-shrink:0}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;display:inline-flex;align-items:center;gap:.25rem}.badge-admin{background:linear-gradient(135deg, #f093fb, #f5576c);color:white}.badge-user{background:rgba(102, 126, 234, 0.15);color:#667eea}.badge-pending,.badge-in_progress{background:rgba(59, 130, 246, 0.15);color:#1e40af}.badge-completed,.badge-done{background:rgba(16, 185, 129, 0.15);color:#065f46}.badge-cancelled,.badge-archived{background:rgba(107, 114, 128, 0.15);color:#374151}.admin-actions-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(150px, 1fr));gap:1rem}.admin-action-card{background:rgba(255, 255, 255, 0.7);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:2px solid rgba(102, 126, 234, 0.15);border-radius:var(--auth-radius-md, 0.5rem);padding:1.5rem 1rem;text-align:center;text-decoration:none;color:var(--auth-text-primary, #1a202c);transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem}.admin-action-card:hover{background:rgba(102, 126, 234, 0.08);border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 20px rgba(102, 126, 234, 0.2)}.action-icon{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(102, 126, 234, 0.2))}.action-label{font-weight:600;font-size:.875rem;color:#667eea}.empty-state{text-align:center;padding:3rem 2rem;color:var(--auth-text-secondary, #718096)}.empty-icon{font-size:3rem;opacity:.5;margin-bottom:1rem}.empty-state p{margin:0;font-size:1rem}@media(max-width: 768px){.glassmorphic-page-container{padding:1rem}.glassmorphic-page-header{padding:1.5rem}.glassmorphic-page-header h1{font-size:1.5rem}.stats-grid-enhanced{grid-template-columns:1fr;gap:1rem;padding:1.5rem}.filters-section{padding:1.5rem}.filters-container{flex-direction:column;align-items:stretch}.filters-left,.filters-right{width:100%;justify-content:space-between}.table-container{padding:1.5rem}.admin-sections-grid{grid-template-columns:1fr;padding:1.5rem}.admin-actions-grid{grid-template-columns:repeat(2, 1fr)}.activity-item{flex-wrap:wrap}.activity-time{width:100%;text-align:left;margin-top:.25rem}}@media(max-width: 480px){.glassmorphic-page-header h1{font-size:1.25rem}.page-icon{font-size:1.5rem}.stat-value{font-size:1.5rem}.stat-icon{font-size:2rem}.admin-actions-grid{grid-template-columns:1fr}}*:focus-visible{outline:3px solid var(--auth-primary, #667eea);outline-offset:2px}@media(prefers-contrast: high){.glassmorphic-content-card,.glassmorphic-section{border-width:2px;border-color:#667eea}.stat-card-gradient{border:2px solid white}}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}@media print{.glassmorphic-content-card{box-shadow:none;border:1px solid #000;background:white}.stat-card-gradient{background:white;color:black;border:1px solid #000}.filters-section,.bulk-actions-bar{display:none}}.sr-only{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden;clip:rect(0, 0, 0, 0);clip-path:inset(50%);white-space:nowrap}.loading-container{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:rgba(255, 255, 255, 0.95);z-index:100}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{width:40px;height:40px;animation:spin 1s linear infinite}.spinner-path{stroke:var(--primary-color, #0066cc);stroke-linecap:round;stroke-dasharray:125;stroke-dashoffset:0;animation:dash 1.5s ease-in-out infinite}@keyframes spin{100%{transform:rotate(360deg)}}@keyframes dash{0%{stroke-dashoffset:125}50%{stroke-dashoffset:0}100%{stroke-dashoffset:-125}}.loading-skeleton{padding:1rem;width:100%}.skeleton-line{height:1rem;margin-bottom:.75rem;background:linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);background-size:200% 100%;border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-line.short{width:60%}@keyframes skeleton-pulse{0%{background-position:200% 0}100%{background-position:-200% 0}}.loading-progress{width:100%;height:4px;background:#e0e0e0;border-radius:2px;overflow:hidden}.loading-progress-bar{height:100%;background:var(--primary-color, #0066cc);border-radius:2px;transition:width .3s ease}.field-error{color:#d32f2f;font-size:.875rem;margin-top:.25rem;display:flex;align-items:center;gap:.25rem}.field-error::before{content:"⚠"}input.is-invalid,textarea.is-invalid,select.is-invalid{border-color:#d32f2f;outline-color:#d32f2f}input.is-invalid:focus,textarea.is-invalid:focus,select.is-invalid:focus{box-shadow:0 0 0 3px rgba(211, 47, 47, 0.1)}.keyboard-shortcuts-modal{max-width:600px;max-height:80vh;border:none;border-radius:8px;box-shadow:0 20px 60px rgba(0, 0, 0, 0.3);padding:0}.keyboard-shortcuts-modal::backdrop{background:rgba(0, 0, 0, 0.5)}.keyboard-shortcuts-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.keyboard-shortcuts-modal .modal-header h2{margin:0;font-size:1.25rem}.keyboard-shortcuts-modal .close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1;opacity:.6}.keyboard-shortcuts-modal .close-button:hover{opacity:1}.keyboard-shortcuts-modal .modal-body{padding:1.5rem;overflow-y:auto}.shortcuts-list{display:grid;gap:.75rem;margin:1rem 0}.shortcut-item{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center}.shortcut-item dt{font-weight:normal}.shortcut-item dd{margin:0;color:#666}kbd{display:inline-block;padding:.25rem .5rem;font-family:ui-monospace,monospace;font-size:.875rem;background:#f5f5f5;border:1px solid #d0d0d0;border-radius:4px;box-shadow:0 2px 0 #d0d0d0}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}}[aria-busy=true]{position:relative;pointer-events:none;user-select:none}@media(prefers-contrast: high){.field-error{font-weight:bold}kbd{border-width:2px}}.sidebar-nav-icon{font-size:1.25rem;display:inline-flex;align-items:center;justify-content:center;line-height:1}.container-fluid.live-session{max-width:1920px;margin:0 auto;padding:1rem}.live-session .row.g-3{margin-left:-0.75rem;margin-right:-0.75rem}.live-session .row.g-3>[class*=col-]{padding-left:.75rem;padding-right:.75rem}@media(max-width: 991.98px){.live-session .col-lg-3{width:100%;margin-bottom:1rem}.live-session .col-lg-6{width:100%}}@media(min-width: 992px)and (max-width: 1199.98px){.live-session .col-lg-3{flex:0 0 25%;max-width:25%}.live-session .col-lg-6{flex:0 0 50%;max-width:50%}}@media(min-width: 1200px){.live-session .col-lg-3{flex:0 0 25%;max-width:25%}.live-session .col-lg-6{flex:0 0 50%;max-width:50%}}.live-session .card{margin-bottom:1rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1);transition:box-shadow .3s ease}.live-session .card:hover{box-shadow:0 4px 16px rgba(0, 0, 0, 0.15)}.live-session .card-body{overflow-x:hidden;overflow-y:auto}.dice-roller-compact{position:relative}.dice-buttons-grid{display:grid;grid-template-columns:repeat(3, 1fr);gap:.5rem;margin-bottom:1rem}@media(min-width: 576px){.dice-buttons-grid{grid-template-columns:repeat(6, 1fr)}}.dice-btn{position:relative;aspect-ratio:1;min-height:60px;border:2px solid;border-radius:12px;background:linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);cursor:pointer;transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);box-shadow:0 2px 4px rgba(0, 0, 0, 0.1);overflow:hidden}.dice-btn:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 16px rgba(0, 0, 0, 0.2)}.dice-btn:active{transform:translateY(-1px) scale(0.98);box-shadow:0 2px 4px rgba(0, 0, 0, 0.15)}.dice-btn:focus-visible{outline:3px solid #ffc107;outline-offset:2px}.dice-d20{border-color:#9c27b0;background:linear-gradient(135deg, #ce93d8 0%, #ab47bc 100%);color:#fff}.dice-d20:hover{background:linear-gradient(135deg, #ab47bc 0%, #8e24aa 100%)}.dice-d12{border-color:#673ab7;background:linear-gradient(135deg, #b39ddb 0%, #7e57c2 100%);color:#fff}.dice-d12:hover{background:linear-gradient(135deg, #7e57c2 0%, #5e35b1 100%)}.dice-d10{border-color:#3f51b5;background:linear-gradient(135deg, #9fa8da 0%, #5c6bc0 100%);color:#fff}.dice-d10:hover{background:linear-gradient(135deg, #5c6bc0 0%, #3949ab 100%)}.dice-d8{border-color:#2196f3;background:linear-gradient(135deg, #90caf9 0%, #42a5f5 100%);color:#fff}.dice-d8:hover{background:linear-gradient(135deg, #42a5f5 0%, #1e88e5 100%)}.dice-d6{border-color:#ffc107;background:linear-gradient(135deg, #ffd54f 0%, #ffb300 100%);color:#212529}.dice-d6:hover{background:linear-gradient(135deg, #ffb300 0%, #ff8f00 100%)}.dice-d4{border-color:#ff9800;background:linear-gradient(135deg, #ffcc80 0%, #fb8c00 100%);color:#212529}.dice-d4:hover{background:linear-gradient(135deg, #fb8c00 0%, #ef6c00 100%)}.dice-icon{font-size:1.25rem;font-weight:700;text-shadow:0 1px 2px rgba(0, 0, 0, 0.2);letter-spacing:-0.5px}.modifier-controls{max-width:100%}.modifier-input-group{display:flex;gap:.5rem;align-items:center}.modifier-input-group input[type=number]{flex:1;max-width:80px;font-size:1.1rem;font-weight:600;padding:.5rem}.modifier-btn{width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;border-radius:8px;transition:all .2s ease}.modifier-btn:hover{transform:scale(1.1);background-color:#6c757d;color:#fff}.modifier-btn:active{transform:scale(0.95)}.adv-disadv-controls{display:flex;gap:.5rem}.adv-btn,.disadv-btn{position:relative;font-weight:600;transition:all .3s ease}.adv-btn[aria-pressed=true]{background-color:#28a745;border-color:#28a745;color:#fff;box-shadow:0 0 12px rgba(40, 167, 69, 0.5)}.disadv-btn[aria-pressed=true]{background-color:#dc3545;border-color:#dc3545;color:#fff;box-shadow:0 0 12px rgba(220, 53, 69, 0.5)}.badge-icon{display:inline-block;font-weight:900;font-size:1.1rem;margin-right:.25rem}.dice-animation{position:fixed;top:50%;left:50%;transform:translate(-50%, -50%);font-size:5rem;font-weight:900;color:#ffc107;text-shadow:0 0 20px rgba(255, 193, 7, 0.8),0 0 40px rgba(255, 193, 7, 0.6),0 0 60px rgba(255, 193, 7, 0.4);z-index:9999;pointer-events:none;animation:diceRollAnimation 1.5s cubic-bezier(0.68, -0.55, 0.265, 1.55)}@keyframes diceRollAnimation{0%{transform:translate(-50%, -50%) scale(0) rotate(0deg);opacity:0}30%{transform:translate(-50%, -50%) scale(1.3) rotate(180deg);opacity:1}60%{transform:translate(-50%, -50%) scale(1) rotate(360deg);opacity:1}100%{transform:translate(-50%, -50%) scale(0.8) rotate(360deg);opacity:0}}.dice-result{background:linear-gradient(135deg, #9c27b0 0%, #673ab7 100%);border-radius:20px;padding:1rem 2rem;box-shadow:0 10px 40px rgba(0, 0, 0, 0.4)}.custom-roll-details summary{padding:.5rem;border-radius:6px;transition:background-color .2s ease}.custom-roll-details summary:hover{background-color:rgba(0, 0, 0, 0.05)}.custom-roll-details[open] summary{margin-bottom:.5rem}.dice-roll-history{max-height:300px;overflow-y:auto;background-color:#f8f9fa}.dice-roll-entry{transition:background-color .2s ease}.dice-roll-entry:hover{background-color:#e9ecef}.dice-btn:focus-visible,.modifier-btn:focus-visible,.adv-btn:focus-visible,.disadv-btn:focus-visible{outline:3px solid #ffc107;outline-offset:2px;z-index:1}@media(prefers-reduced-motion: reduce){.dice-btn,.modifier-btn,.dice-animation{transition:none;animation:none}.dice-btn:hover{transform:none}}.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}@media(max-width: 575.98px){.dice-icon{font-size:1rem}.dice-btn{min-height:50px}.dice-animation{font-size:3rem}}.roll-item{transition:all .3s ease;border-radius:8px}.roll-item:hover{transform:translateX(5px);box-shadow:0 2px 8px rgba(0, 0, 0, 0.1)}.roll-gold{background-color:#fff9e6;border:2px solid #ffc107 !important}.roll-red{background-color:#ffe6e6;border:2px solid #dc3545 !important}.roll-green{background-color:#e6f9e6;border:2px solid #28a745 !important}.roll-light_green{background-color:#f0fff0;border:2px solid #90ee90 !important}.roll-dark_red{background-color:#fcc;border:2px solid darkred !important}.roll-mine{background-color:#e6f2ff;border:2px solid #007bff !important}.roll-hidden{background-color:#f5f5f5;border-style:dashed !important}.roll-explanation{font-family:"Courier New",monospace;white-space:pre-wrap;background-color:rgba(0, 0, 0, 0.03);padding:.5rem;border-radius:.25rem;font-size:.85rem}.status-indicator{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:.5rem}.status-online{background-color:#28a745;box-shadow:0 0 6px rgba(40, 167, 69, 0.6)}.status-away{background-color:#ffc107;box-shadow:0 0 6px rgba(255, 193, 7, 0.6)}.status-offline{background-color:#6c757d}.chat-message{padding:.75rem;margin-bottom:.5rem;border-radius:8px;background-color:#f8f9fa;transition:background-color .2s ease}.chat-message:hover{background-color:#e9ecef}.chat-message.whisper{background-color:#fff3cd;border-left:4px solid #ffc107}.chat-message.emote{background-color:#d1ecf1;border-left:4px solid #17a2b8;font-style:italic}#combat-tracker-container{min-height:200px}.combat-tracker-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.btn-loading{position:relative;color:transparent !important;pointer-events:none;cursor:wait}.btn-loading::after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid currentColor;border-radius:50%;border-right-color:transparent;animation:btn-spin .6s linear infinite;opacity:.8}@keyframes btn-spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.btn-loading .button-text{visibility:hidden}.btn-loading .button-loading{display:inline-block !important;visibility:visible}@keyframes btn-success-flash{0%{background-color:var(--btn-original-bg, currentColor)}15%{background-color:#10b981;box-shadow:0 0 20px rgba(16, 185, 129, 0.6);transform:scale(1.05)}100%{background-color:var(--btn-original-bg, currentColor)}}.btn-success-flash{animation:btn-success-flash .8s ease-out}@keyframes btn-error-shake{0%,100%{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}.btn-error-shake{animation:btn-error-shake .5s ease-in-out}.skeleton-loader{padding:var(--space-lg, 1rem);opacity:0;animation:skeleton-fade-in .3s ease-in forwards}.skeleton-loader.skeleton-visible{opacity:1}@keyframes skeleton-fade-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.skeleton-fade-out{animation:skeleton-fade-out .3s ease-out forwards}@keyframes skeleton-fade-out{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.skeleton-line{height:16px;background:linear-gradient(90deg, rgba(212, 175, 55, 0.1) 0%, rgba(212, 175, 55, 0.1) 25%, rgba(212, 175, 55, 0.2) 50%, rgba(212, 175, 55, 0.1) 75%, rgba(212, 175, 55, 0.1) 100%);background-size:200% 100%;border-radius:var(--radius-sm, 4px);margin-bottom:var(--space-sm, 0.5rem);animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}.skeleton-line.skeleton-title{height:24px;width:60%;margin-bottom:var(--space-md, 0.75rem)}.skeleton-line.skeleton-short{width:40%}.skeleton-line.skeleton-tiny{width:30%;height:12px}.skeleton-line.skeleton-full{width:100%}.skeleton-circle{width:48px;height:48px;border-radius:50%;background:linear-gradient(90deg, rgba(212, 175, 55, 0.1) 25%, rgba(212, 175, 55, 0.2) 50%, rgba(212, 175, 55, 0.1) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;flex-shrink:0}.skeleton-btn{height:36px;width:100px;border-radius:var(--radius-md, 6px);background:linear-gradient(90deg, rgba(212, 175, 55, 0.1) 25%, rgba(212, 175, 55, 0.2) 50%, rgba(212, 175, 55, 0.1) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}.skeleton-item-icon{width:64px;height:64px;border-radius:var(--radius-sm, 4px);background:linear-gradient(90deg, rgba(212, 175, 55, 0.1) 25%, rgba(212, 175, 55, 0.2) 50%, rgba(212, 175, 55, 0.1) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;margin:0 auto var(--space-sm, 0.5rem)}.skeleton-card{padding:var(--space-lg, 1rem);background:rgba(255, 255, 255, 0.5);border-radius:var(--radius-lg, 8px);border:2px solid rgba(212, 175, 55, 0.1)}.skeleton-list{display:flex;flex-direction:column;gap:var(--space-md, 0.75rem)}.skeleton-list-item{display:flex;align-items:center;gap:var(--space-md, 0.75rem);padding:var(--space-md, 0.75rem);background:rgba(255, 255, 255, 0.5);border-radius:var(--radius-md, 6px);border:1px solid rgba(212, 175, 55, 0.1)}.skeleton-list-content{flex:1}.skeleton-table{display:flex;flex-direction:column;gap:var(--space-sm, 0.5rem)}.skeleton-table-header{display:grid;grid-template-columns:repeat(3, 1fr);gap:var(--space-md, 0.75rem);padding:var(--space-md, 0.75rem);background:rgba(212, 175, 55, 0.05);border-radius:var(--radius-md, 6px);border-bottom:2px solid rgba(212, 175, 55, 0.2)}.skeleton-table-row{display:grid;grid-template-columns:repeat(3, 1fr);gap:var(--space-md, 0.75rem);padding:var(--space-md, 0.75rem);background:rgba(255, 255, 255, 0.5);border-radius:var(--radius-sm, 4px);border:1px solid rgba(212, 175, 55, 0.1)}.skeleton-spell-card{background:linear-gradient(135deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 250, 252, 0.95) 100%);border:2px solid rgba(139, 92, 246, 0.2);border-radius:var(--radius-lg, 8px);overflow:hidden;box-shadow:0 4px 6px rgba(0, 0, 0, 0.1)}.skeleton-spell-header{background:linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, rgba(245, 158, 11, 0.05) 100%);border-bottom:2px solid rgba(212, 175, 55, 0.2);padding:var(--space-md, 0.75rem)}.skeleton-spell-body{padding:var(--space-md, 0.75rem)}.skeleton-spell-stats{display:grid;grid-template-columns:repeat(3, 1fr);gap:var(--space-sm, 0.5rem);margin-bottom:var(--space-md, 0.75rem);padding-bottom:var(--space-md, 0.75rem);border-bottom:1px solid rgba(212, 175, 55, 0.1)}.skeleton-stat{text-align:center}.skeleton-spell-footer{display:flex;gap:var(--space-sm, 0.5rem);padding:var(--space-md, 0.75rem);border-top:1px solid rgba(212, 175, 55, 0.1);background:rgba(248, 250, 252, 0.5)}.skeleton-inventory-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(100px, 1fr));gap:var(--space-md, 0.75rem);padding:var(--space-md, 0.75rem)}.skeleton-inventory-item{display:flex;flex-direction:column;align-items:center;padding:var(--space-sm, 0.5rem);background:rgba(255, 255, 255, 0.5);border:2px solid rgba(212, 175, 55, 0.1);border-radius:var(--radius-md, 6px);aspect-ratio:1;justify-content:center}.optimistic-update{opacity:.6;position:relative}.optimistic-update::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:2px solid rgba(212, 175, 55, 0.5);border-radius:inherit;animation:optimistic-pulse 1.5s ease-in-out infinite;pointer-events:none}@keyframes optimistic-pulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.optimistic-confirmed{animation:optimistic-confirm .6s ease-out}@keyframes optimistic-confirm{0%{opacity:.6}50%{background-color:rgba(16, 185, 129, 0.2);transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}.optimistic-rollback{animation:optimistic-rollback .5s ease-in-out}@keyframes optimistic-rollback{0%,100%{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-4px)}20%,40%,60%,80%{transform:translateX(4px)}}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255, 255, 255, 0.9);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:inherit;opacity:0;animation:loading-overlay-fade-in .2s ease-in forwards}@keyframes loading-overlay-fade-in{to{opacity:1}}.loading-overlay-spinner{width:48px;height:48px;border:4px solid rgba(212, 175, 55, 0.2);border-top-color:#d4af37;border-radius:50%;animation:loading-overlay-spin .8s linear infinite}@keyframes loading-overlay-spin{to{transform:rotate(360deg)}}.progressive-load{opacity:0;transform:translateY(20px);animation:progressive-load-in .4s ease-out forwards}@keyframes progressive-load-in{to{opacity:1;transform:translateY(0)}}.progressive-load-container>*{opacity:0;transform:translateY(20px)}.progressive-load-container.loading-complete>*:nth-child(1){animation:progressive-load-in .3s ease-out .05s forwards}.progressive-load-container.loading-complete>*:nth-child(2){animation:progressive-load-in .3s ease-out .1s forwards}.progressive-load-container.loading-complete>*:nth-child(3){animation:progressive-load-in .3s ease-out .15s forwards}.progressive-load-container.loading-complete>*:nth-child(4){animation:progressive-load-in .3s ease-out .2s forwards}.progressive-load-container.loading-complete>*:nth-child(5){animation:progressive-load-in .3s ease-out .25s forwards}.progressive-load-container.loading-complete>*:nth-child(n+6){animation:progressive-load-in .3s ease-out .3s forwards}@media(max-width: 768px){.skeleton-spell-stats{grid-template-columns:1fr}.skeleton-table-header,.skeleton-table-row{grid-template-columns:1fr}.skeleton-inventory-grid{grid-template-columns:repeat(auto-fill, minmax(80px, 1fr))}}@media(prefers-reduced-motion: reduce){.skeleton-line,.skeleton-circle,.skeleton-btn,.skeleton-item-icon,.btn-loading::after,.loading-overlay-spinner{animation:none}.skeleton-line,.skeleton-circle,.skeleton-btn,.skeleton-item-icon{background:rgba(212, 175, 55, 0.15)}.optimistic-update::after{animation:none;opacity:.5}}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg, rgba(139, 92, 246, 0.1) 0%, rgba(139, 92, 246, 0.1) 25%, rgba(139, 92, 246, 0.2) 50%, rgba(139, 92, 246, 0.1) 75%, rgba(139, 92, 246, 0.1) 100%);background-size:200% 100%}[data-theme=dark] .skeleton-circle,[data-theme=dark] .skeleton-btn,[data-theme=dark] .skeleton-item-icon{background:linear-gradient(90deg, rgba(139, 92, 246, 0.1) 25%, rgba(139, 92, 246, 0.2) 50%, rgba(139, 92, 246, 0.1) 75%);background-size:200% 100%}[data-theme=dark] .skeleton-card{background:rgba(30, 41, 59, 0.5);border-color:rgba(139, 92, 246, 0.2)}[data-theme=dark] .skeleton-list-item{background:rgba(30, 41, 59, 0.5);border-color:rgba(139, 92, 246, 0.2)}[data-theme=dark] .skeleton-table-header{background:rgba(139, 92, 246, 0.05);border-bottom-color:rgba(139, 92, 246, 0.3)}[data-theme=dark] .skeleton-table-row{background:rgba(30, 41, 59, 0.5);border-color:rgba(139, 92, 246, 0.2)}[data-theme=dark] .skeleton-spell-card{background:linear-gradient(135deg, rgba(30, 41, 59, 0.95) 0%, rgba(15, 23, 42, 0.95) 100%);border-color:rgba(139, 92, 246, 0.3);box-shadow:0 4px 6px rgba(0, 0, 0, 0.4)}[data-theme=dark] .skeleton-spell-header{background:linear-gradient(135deg, rgba(139, 92, 246, 0.15) 0%, rgba(236, 72, 153, 0.1) 100%);border-bottom-color:rgba(139, 92, 246, 0.3)}[data-theme=dark] .skeleton-spell-stats{border-bottom-color:rgba(139, 92, 246, 0.2)}[data-theme=dark] .skeleton-spell-footer{background:rgba(15, 23, 42, 0.5);border-top-color:rgba(139, 92, 246, 0.2)}[data-theme=dark] .skeleton-inventory-item{background:rgba(30, 41, 59, 0.5);border-color:rgba(139, 92, 246, 0.2)}[data-theme=dark] .loading-overlay{background:rgba(15, 23, 42, 0.9)}[data-theme=dark] .loading-overlay-spinner{border-color:rgba(139, 92, 246, 0.3);border-top-color:#8b5cf6}[data-theme=dark] .optimistic-update::after{border-color:rgba(139, 92, 246, 0.6)}[data-theme=dark] .btn-loading::after{border-color:rgba(255, 255, 255, 0.3);border-right-color:transparent}@media print{.skeleton-loader,.loading-overlay,.btn-loading::after{display:none}[data-theme=dark] .skeleton-card,[data-theme=dark] .skeleton-list-item,[data-theme=dark] .skeleton-spell-card{background:white !important;border-color:#ccc !important}}.npcs-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.5rem;margin-top:2rem}.npc-card{background:linear-gradient(135deg, #ffffff 0%, #f8f9fa 100%);border:2px solid #dee2e6;border-radius:1rem;overflow:hidden;transition:all .3s ease;box-shadow:0 4px 6px rgba(0, 0, 0, 0.1);position:relative}.npc-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px rgba(0, 0, 0, 0.15);border-color:#0d6efd}.npc-card.archived{opacity:.7;background:linear-gradient(135deg, #e9ecef 0%, #dee2e6 100%);border-style:dashed}.npc-portrait-section{position:relative;height:200px;background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);display:flex;align-items:center;justify-content:center;overflow:hidden}.npc-portrait-placeholder{font-size:5rem;opacity:.9;filter:drop-shadow(0 4px 6px rgba(0, 0, 0, 0.2))}.npc-importance-badge{position:absolute;top:1rem;right:1rem;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.2);background:rgba(255, 255, 255, 0.9)}.npc-importance-badge.critical{background:linear-gradient(135deg, #dc3545, #bd2130);color:white}.npc-importance-badge.major{background:linear-gradient(135deg, #ffc107, #e0a800);color:white}.npc-importance-badge.minor{background:linear-gradient(135deg, #17a2b8, #138496);color:white}.npc-importance-badge.background{background:linear-gradient(135deg, #6c757d, #5a6268);color:white}.npc-card-body{padding:1.5rem}.npc-card-name{font-size:1.3rem;font-weight:700;margin-bottom:.5rem;color:#212529;line-height:1.2}.npc-card-details{color:#6c757d;font-size:.95rem;margin-bottom:.75rem}.npc-card-occupation{font-size:.9rem;color:#495057;margin-bottom:1rem;padding:.5rem .75rem;background:#f8f9fa;border-radius:.5rem;border-left:3px solid #0d6efd}.npc-meta-info{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.npc-meta-badge{font-size:.8rem;padding:.35rem .75rem;border-radius:1rem;background:#e9ecef;color:#495057;display:inline-flex;align-items:center;gap:.25rem}.npc-meta-badge.faction{background:linear-gradient(135deg, rgba(13, 110, 253, 0.0823529412), rgba(13, 110, 253, 0.1882352941));border:1px solid rgba(13,110,253,.3137254902)}.npc-meta-badge.location{background:linear-gradient(135deg, rgba(25, 135, 84, 0.0823529412), rgba(25, 135, 84, 0.1882352941));border:1px solid rgba(25,135,84,.3137254902)}.npc-status-section{margin-bottom:1rem}.npc-status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:1.5rem;font-size:.9rem;font-weight:600}.npc-status-badge.friendly{background:linear-gradient(135deg, rgba(25, 135, 84, 0.1254901961), rgba(25, 135, 84, 0.2509803922));color:#198754;border:1px solid #198754}.npc-status-badge.neutral{background:linear-gradient(135deg, rgba(108, 117, 125, 0.1254901961), rgba(108, 117, 125, 0.2509803922));color:#6c757d;border:1px solid #6c757d}.npc-status-badge.hostile{background:linear-gradient(135deg, rgba(220, 53, 69, 0.1254901961), rgba(220, 53, 69, 0.2509803922));color:#dc3545;border:1px solid #dc3545}.npc-status-badge.alive{background:linear-gradient(135deg, rgba(25, 135, 84, 0.1254901961), rgba(25, 135, 84, 0.2509803922));color:#198754;border:1px solid #198754}.npc-status-badge.dead{background:linear-gradient(135deg, rgba(33, 37, 41, 0.1254901961), rgba(33, 37, 41, 0.2509803922));color:#212529;border:1px solid #212529}.npc-status-badge.missing{background:linear-gradient(135deg, rgba(255, 193, 7, 0.1254901961), rgba(255, 193, 7, 0.2509803922));color:#ffc107;border:1px solid #ffc107}.npc-quick-info{margin-bottom:1rem;padding:.75rem;background:#f8f9fa;border-radius:.5rem;font-size:.875rem;font-style:italic}.npc-interaction-count{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:linear-gradient(135deg, rgba(13, 110, 253, 0.062745098), rgba(13, 110, 253, 0.1254901961));border-radius:.5rem;border:1px solid rgba(13,110,253,.1882352941)}.interaction-icon{font-size:1.2rem}.interaction-number{font-size:1.3rem;font-weight:700;color:#0d6efd}.interaction-label{font-size:.85rem;color:#6c757d}.npc-card-actions{padding:1rem;background:#f8f9fa;border-top:1px solid #dee2e6;display:flex;gap:.5rem;flex-wrap:wrap}.btn-card-action{flex:1;min-width:calc(50% - .25rem);padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;font-weight:600;text-align:center;text-decoration:none;transition:all .2s;border:1px solid transparent}.btn-card-action.btn-primary{background:#0d6efd;color:white}.btn-card-action.btn-primary:hover{background:#0b5ed7;transform:translateY(-1px)}.btn-card-action.btn-secondary{background:#6c757d;color:white}.btn-card-action.btn-secondary:hover{background:#5a6268;transform:translateY(-1px)}.btn-card-action.btn-warning{background:#ffc107;color:#000}.btn-card-action.btn-warning:hover{background:#e0a800;transform:translateY(-1px)}.btn-card-action.btn-success{background:#198754;color:white}.btn-card-action.btn-success:hover{background:#157347;transform:translateY(-1px)}.relationship-meter{padding:.75rem;background:#f8f9fa;border-radius:.5rem}.relationship-meter .progress{height:10px;border-radius:5px;overflow:hidden;background:#e9ecef}.relationship-meter .progress-bar{transition:width .6s ease}.view-switcher{display:flex;gap:.5rem;padding:.25rem;background:#f8f9fa;border-radius:.5rem;margin-right:1rem}.view-option{padding:.5rem 1rem;border-radius:.375rem;text-decoration:none;color:#6c757d;font-weight:600;transition:all .2s;border:none;background:transparent}.view-option:hover{background:#e9ecef;color:#495057}.view-option.active{background:white;color:#0d6efd;box-shadow:0 2px 4px rgba(0, 0, 0, 0.1)}.npcs-empty-state{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);border-radius:1rem;margin-top:2rem}.empty-state-icon{font-size:4rem;display:block;margin-bottom:1.5rem;opacity:.5}.empty-state-title{font-size:1.75rem;font-weight:700;color:#495057;margin-bottom:1rem}.empty-state-text{font-size:1.1rem;color:#6c757d;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}@media(max-width: 768px){.npcs-grid{grid-template-columns:1fr}.filters-grid{grid-template-columns:1fr !important}.npc-card-actions{flex-direction:column}.btn-card-action{min-width:100%}.stats-overview-cards{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 769px)and (max-width: 1024px){.npcs-grid{grid-template-columns:repeat(2, 1fr)}}.npc-card:focus-within{outline:3px solid #0d6efd;outline-offset:2px}.btn-card-action:focus{outline:2px solid #0d6efd;outline-offset:2px}.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}@media print{.npc-card{break-inside:avoid;page-break-inside:avoid}.filters-section,.btn-card-action,.npc-card-actions{display:none}.npcs-grid{grid-template-columns:repeat(2, 1fr);gap:1rem}}@keyframes slideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.npc-card{animation:slideIn .3s ease-out}.npc-card:nth-child(1){animation-delay:.05s}.npc-card:nth-child(2){animation-delay:.1s}.npc-card:nth-child(3){animation-delay:.15s}.npc-card:nth-child(4){animation-delay:.2s}.npc-card:nth-child(5){animation-delay:.25s}.npc-card:nth-child(6){animation-delay:.3s}@media(prefers-reduced-motion: reduce){.npc-card{animation:none}.npc-card:hover{transform:none}.btn-card-action:hover{transform:none}}@media(prefers-contrast: high){.npc-card{border-width:3px;border-color:#000}.npc-status-badge{border-width:2px}.btn-card-action{border-width:2px;border-color:currentColor}}@media(prefers-color-scheme: dark){.npc-card{background:linear-gradient(135deg, #2d3748 0%, #1a202c 100%);border-color:#4a5568;color:#e2e8f0}.npc-card-name{color:#f7fafc}.npc-card-details,.npc-card-occupation{color:#cbd5e0;background:#2d3748}.npc-quick-info{background:#2d3748;color:#cbd5e0}.npc-card-actions{background:#2d3748;border-top-color:#4a5568}.npcs-empty-state{background:linear-gradient(135deg, #2d3748 0%, #1a202c 100%)}.empty-state-title{color:#f7fafc}.empty-state-text{color:#cbd5e0}}.ai-chat-container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.ai-chat-header{background:linear-gradient(135deg, #d97706 0%, #92400e 100%);color:white;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 12px rgba(139, 92, 246, 0.3)}.ai-chat-title{font-size:2rem;font-weight:700;margin-bottom:.5rem}.ai-chat-subtitle{opacity:.9;font-size:1.1rem}.ai-chat-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));gap:1rem;margin-top:1.5rem}.ai-stat-card{background:rgba(255, 255, 255, 0.2);border-radius:8px;padding:1rem;text-align:center;backdrop-filter:blur(10px)}.ai-stat-value{font-size:1.5rem;font-weight:700;display:block}.ai-stat-label{font-size:.875rem;opacity:.9;text-transform:uppercase;letter-spacing:.05em}.chat-messages{background:white;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1);max-height:600px;overflow-y:auto}.chat-message{margin-bottom:1.5rem;display:flex;gap:1rem;animation:messageSlideIn .3s ease-out}@keyframes messageSlideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.dm-message{flex-direction:row}.chat-message.player-message{flex-direction:row-reverse}.message-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.message-avatar.dm-avatar{background:linear-gradient(135deg, #dc3545 0%, #c82333 100%);color:white;box-shadow:0 4px 12px rgba(220, 53, 69, 0.3)}.message-avatar.player-avatar{background:linear-gradient(135deg, #0d6efd 0%, #0a58ca 100%);color:white;box-shadow:0 4px 12px rgba(13, 110, 253, 0.3)}.message-content{flex:1;max-width:70%}.message-bubble{padding:1rem 1.25rem;border-radius:12px;margin-bottom:.5rem}.dm-message .message-bubble{background:linear-gradient(135deg, #fee 0%, #fdd 100%);border-left:4px solid #dc3545}.player-message .message-bubble{background:linear-gradient(135deg, #e7f3ff 0%, #d6ebff 100%);border-right:4px solid #0d6efd}.message-text{color:#212529;line-height:1.6;margin:0;white-space:pre-wrap;word-wrap:break-word}.message-metadata{display:flex;gap:1rem;font-size:.75rem;color:#6c757d;margin-top:.25rem}.message-time{font-weight:500}.message-tokens{color:#d97706}.dice-roll-display{background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);border:2px solid #fbbf24;border-radius:8px;padding:.75rem 1rem;margin-top:.5rem;display:flex;align-items:center;gap:.75rem}.dice-roll-icon{font-size:1.5rem}.dice-roll-text{flex:1;font-weight:600;color:#92400e}.dice-roll-result{font-size:1.25rem;font-weight:700;color:#92400e;padding:.25rem .75rem;background:rgba(255, 255, 255, 0.5);border-radius:6px}.narrative-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.narrative-tag{background:rgba(139, 92, 246, 0.1);color:#d97706;border:1px solid rgba(139, 92, 246, 0.3);padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.chat-input-container{background:white;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1)}.chat-input-form{display:flex;gap:1rem}.chat-input-field{flex:1;padding:.875rem 1.25rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .2s ease}.chat-input-field:focus{outline:none;border-color:#d97706;box-shadow:0 0 0 3px rgba(139, 92, 246, 0.1)}.chat-send-button{padding:.875rem 2rem;background:linear-gradient(135deg, #d97706 0%, #92400e 100%);color:white;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.chat-send-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.3)}.chat-send-button:active{transform:translateY(0)}.quest-container{max-width:1000px;margin:0 auto;padding:2rem 1rem}.quest-header{background:linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);color:#78350f;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 12px rgba(251, 191, 36, 0.3);position:relative;overflow:hidden}.quest-header::before{content:"⚔️";position:absolute;right:2rem;top:50%;transform:translateY(-50%);font-size:6rem;opacity:.2}.quest-title{font-size:2rem;font-weight:700;margin-bottom:.5rem;position:relative;z-index:1}.quest-type-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:rgba(255, 255, 255, 0.3);margin-right:.5rem}.quest-difficulty-badge{display:inline-block;padding:.25rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.quest-difficulty-badge.easy{background:#10b981;color:white}.quest-difficulty-badge.medium{background:#f59e0b;color:white}.quest-difficulty-badge.hard{background:#f97316;color:white}.quest-difficulty-badge.deadly{background:#dc3545;color:white}.quest-description{font-size:1.1rem;line-height:1.6;margin-top:1rem;position:relative;z-index:1}.quest-progress-card{background:white;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1)}.quest-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.quest-status-badge{padding:.5rem 1rem;border-radius:8px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.875rem}.quest-status-badge.active{background:#0d6efd;color:white}.quest-status-badge.completed{background:#10b981;color:white}.quest-status-badge.failed{background:#dc3545;color:white}.quest-xp-reward{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;color:#d97706}.quest-xp-icon{font-size:1.5rem}.quest-objectives{margin-top:1.5rem}.quest-objectives-title{font-size:1.25rem;font-weight:700;color:#212529;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.objectives-list{list-style:none;padding:0;margin:0}.objective-item{background:linear-gradient(135deg, #f9fafb 0%, #ffffff 100%);border:2px solid #e5e7eb;border-radius:12px;padding:1rem 1.25rem;margin-bottom:.75rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.objective-item:hover{border-color:#d97706;transform:translateX(4px)}.objective-item.completed{background:linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);border-color:#10b981}.objective-item.completed .objective-text{text-decoration:line-through;color:#6b7280}.objective-checkbox{width:24px;height:24px;border-radius:50%;border:2px solid #9ca3af;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.objective-item.completed .objective-checkbox{background:#10b981;border-color:#10b981;color:white}.objective-text{flex:1;font-size:1rem;color:#374151}.objective-optional{font-size:.75rem;color:#d97706;background:rgba(139, 92, 246, 0.1);padding:.25rem .5rem;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.objective-progress{margin-top:.5rem}.objective-progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.objective-progress-fill{height:100%;background:linear-gradient(90deg, #d97706 0%, #92400e 100%);transition:width .3s ease}.objective-progress-text{font-size:.75rem;color:#6c757d;margin-top:.25rem}.quest-timeline{margin-top:2rem;padding-top:2rem;border-top:2px solid #e5e7eb}.timeline-item{display:flex;gap:1rem;margin-bottom:1rem}.timeline-icon{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg, #d97706 0%, #92400e 100%);color:white;display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-content{flex:1}.timeline-label{font-weight:600;color:#6c757d;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.timeline-value{color:#212529;font-size:1rem}.solo-session-container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.solo-session-header{background:linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);color:white;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 4px 12px rgba(99, 102, 241, 0.3)}.solo-session-title{font-size:2rem;font-weight:700;margin-bottom:.5rem}.solo-session-subtitle{opacity:.9;font-size:1.1rem}.solo-session-grid{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-bottom:2rem}.narrative-log-card{background:white;border-radius:16px;padding:2rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1)}.narrative-log-title{font-size:1.5rem;font-weight:700;color:#212529;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.narrative-entry{background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);border-left:4px solid #fbbf24;border-radius:8px;padding:1.5rem;margin-bottom:1rem;font-style:italic;line-height:1.7;color:#92400e}.session-actions-card{background:white;border-radius:16px;padding:2rem;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1)}.session-actions-title{font-size:1.25rem;font-weight:700;color:#212529;margin-bottom:1rem}.session-action-button{width:100%;padding:1rem;margin-bottom:.75rem;background:linear-gradient(135deg, #f9fafb 0%, #ffffff 100%);border:2px solid #e5e7eb;border-radius:12px;font-weight:600;color:#374151;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.75rem;text-decoration:none}.session-action-button:hover{border-color:#d97706;background:linear-gradient(135deg, #f3e8ff 0%, #e9d5ff 100%);transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.2)}.session-action-icon{font-size:1.5rem}.session-state-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.session-state-badge.active{background:#10b981;color:white}.session-state-badge.paused{background:#f59e0b;color:white}.session-state-badge.ended{background:#6c757d;color:white}@media(max-width: 768px){.ai-chat-stats{grid-template-columns:1fr}.chat-message{flex-direction:column !important}.message-content{max-width:100%}.solo-session-grid{grid-template-columns:1fr}.quest-header::before{font-size:3rem;right:1rem}}@media(max-width: 480px){.ai-chat-title,.quest-title,.solo-session-title{font-size:1.5rem}.chat-input-form{flex-direction:column}.chat-send-button{width:100%}}.vtt-container{display:flex;flex-direction:column;height:100vh;background:#0d1117;color:#c9d1d9;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif}.vtt-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:linear-gradient(135deg, #161b22 0%, #0d1117 100%);border-bottom:1px solid #30363d;box-shadow:0 2px 8px rgba(0, 0, 0, 0.3);flex-shrink:0;z-index:100}.toolbar-section{display:flex;align-items:center;gap:.5rem}.vtt-main{display:flex;flex:1;min-height:0;position:relative}.vtt-sidebar{width:280px;background:#161b22;border-right:1px solid #30363d;display:flex;flex-direction:column;overflow:hidden;z-index:50}.vtt-sidebar-right{border-right:none;border-left:1px solid #30363d}.sidebar-header{padding:1rem;background:#0d1117;border-bottom:1px solid #30363d;flex-shrink:0}.sidebar-header h5{margin:0;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#8b949e}.sidebar-content{flex:1;overflow-y:auto;padding:1rem}.sidebar-content::-webkit-scrollbar{width:8px}.sidebar-content::-webkit-scrollbar-track{background:#0d1117}.sidebar-content::-webkit-scrollbar-thumb{background:#30363d;border-radius:4px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#58a6ff}.vtt-canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:#0d1117;position:relative;overflow:hidden}canvas{display:block;max-width:100%;max-height:100%;cursor:crosshair;box-shadow:0 8px 32px rgba(0, 0, 0, 0.5);image-rendering:crisp-edges;image-rendering:-moz-crisp-edges;image-rendering:pixelated}canvas:focus{outline:2px solid #58a6ff;outline-offset:4px}.vtt-overlay-bottom{position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);pointer-events:none;z-index:10}.vtt-overlay-top-right{position:absolute;top:1rem;right:1rem;pointer-events:none;z-index:10}.vtt-coordinates{background:rgba(13, 17, 23, 0.9);padding:.5rem 1rem;border-radius:.375rem;border:1px solid #30363d;font-family:"Courier New",monospace;font-size:.875rem;box-shadow:0 4px 16px rgba(0, 0, 0, 0.3);backdrop-filter:blur(10px)}.connection-status{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:rgba(13, 17, 23, 0.95);border-radius:.375rem;border:1px solid #30363d;font-size:.75rem;font-weight:500;box-shadow:0 2px 8px rgba(0, 0, 0, 0.3);backdrop-filter:blur(10px);transition:all .3s ease}.status-dot{width:8px;height:8px;border-radius:50%;position:relative;flex-shrink:0}.status-connected{border-color:#238636}.status-connected .status-dot{background:#2ea043;box-shadow:0 0 8px rgba(46, 160, 67, 0.6);animation:pulse-green 2s ease-in-out infinite}.status-connected .status-text{color:#2ea043}.status-disconnected{border-color:#da3633}.status-disconnected .status-dot{background:#f85149;box-shadow:0 0 8px rgba(248, 81, 73, 0.6)}.status-disconnected .status-text{color:#f85149}.status-connecting{border-color:#9e6a03}.status-connecting .status-dot{background:#d29922;box-shadow:0 0 8px rgba(210, 153, 34, 0.6);animation:pulse-yellow 1.5s ease-in-out infinite}.status-connecting .status-text{color:#d29922}@keyframes pulse-green{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}@keyframes pulse-yellow{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.vtt-update-notification{position:fixed;top:5rem;left:50%;transform:translateX(-50%) translateY(-100px);padding:.75rem 1.5rem;background:rgba(13, 17, 23, 0.95);border:1px solid #58a6ff;border-radius:.5rem;font-size:.875rem;font-weight:500;color:#58a6ff;box-shadow:0 4px 16px rgba(88, 166, 255, 0.3);backdrop-filter:blur(10px);opacity:0;transition:all .3s ease;z-index:1000;pointer-events:none}.vtt-notification-show{opacity:1;transform:translateX(-50%) translateY(0)}.vtt-notification-info{border-color:#58a6ff;color:#58a6ff;box-shadow:0 4px 16px rgba(88, 166, 255, 0.3)}.vtt-notification-success{border-color:#2ea043;color:#2ea043;box-shadow:0 4px 16px rgba(46, 160, 67, 0.3)}.vtt-notification-warning{border-color:#d29922;color:#d29922;box-shadow:0 4px 16px rgba(210, 153, 34, 0.3)}.terrain-palette{display:grid;grid-template-columns:1fr;gap:.5rem}.terrain-button{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#0d1117;border:2px solid #30363d;border-radius:.375rem;color:#c9d1d9;cursor:pointer;transition:all .2s ease;user-select:none}.terrain-button:hover{background:#161b22;border-color:#58a6ff;transform:translateY(-2px);box-shadow:0 4px 8px rgba(88, 166, 255, 0.2)}.terrain-button:active{transform:translateY(0)}.terrain-button.active{background:#1f6feb;border-color:#58a6ff;box-shadow:0 0 16px rgba(88, 166, 255, 0.3)}.terrain-icon{font-size:1.5rem;flex-shrink:0;line-height:1}.terrain-label{font-weight:500;font-size:.875rem}.token-list{display:flex;flex-direction:column;gap:.75rem}.token-list-item{padding:.75rem;background:#0d1117;border-radius:.375rem;border:1px solid #30363d;transition:all .2s ease;cursor:pointer}.token-list-item:hover{background:#161b22;border-color:#58a6ff;transform:translateX(4px);box-shadow:0 2px 8px rgba(88, 166, 255, 0.15)}.hp-bar-container{margin-top:.5rem}.hp-display{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;color:#c9d1d9;background:#161b22;border:1px solid #30363d;border-radius:.25rem;min-width:70px}.btn-xs{padding:.125rem .5rem;font-size:.7rem;line-height:1.5;border-radius:.2rem}.btn-outline-danger:hover{background-color:#f85149;border-color:#f85149}.btn-outline-success:hover{background-color:#2ea043;border-color:#2ea043}.token-card{background:#0d1117;border:1px solid #30363d;border-radius:.375rem;padding:.75rem;height:100%;transition:all .2s ease}.token-card:hover{background:#161b22;border-color:#58a6ff;transform:translateY(-2px);box-shadow:0 4px 16px rgba(88, 166, 255, 0.2)}.token-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-weight:bold;font-size:1.25rem;flex-shrink:0;box-shadow:0 2px 8px rgba(0, 0, 0, 0.3)}.vtt-info-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 1rem;background:#161b22;border-top:1px solid #30363d;font-size:.75rem;flex-shrink:0}.info-item{display:flex;align-items:center;gap:.5rem;color:#8b949e}.vtt-info-panel{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(0deg, rgba(13, 17, 23, 0.98) 0%, rgba(13, 17, 23, 0.9) 100%);border-top:1px solid #30363d;backdrop-filter:blur(10px);z-index:1000}.info-panel-toggle{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.5rem;background:transparent;border:none;color:#8b949e;cursor:pointer;transition:all .2s ease}.info-panel-toggle:hover{color:#c9d1d9;background:rgba(255, 255, 255, 0.05)}.info-panel-toggle i{transition:transform .2s ease}.info-panel-toggle[aria-expanded=true] i{transform:rotate(180deg)}.info-panel-content{padding:1rem 1.5rem 1.5rem;max-height:300px;overflow-y:auto}kbd{padding:.125rem .375rem;background:#0d1117;border:1px solid #30363d;border-radius:.25rem;font-family:"Courier New",monospace;font-size:.75rem;color:#c9d1d9;box-shadow:0 1px 2px rgba(0, 0, 0, 0.2)}@media(max-width: 1200px){.vtt-sidebar{width:240px}}@media(max-width: 992px){.vtt-sidebar-left{display:none}.vtt-sidebar-right{width:200px}.terrain-palette{grid-template-columns:repeat(2, 1fr)}}@media(max-width: 768px){.vtt-main{flex-direction:column}.vtt-sidebar-right{width:100%;max-height:200px;border-left:none;border-top:1px solid #30363d}.vtt-info-bar{flex-direction:column;gap:.5rem;align-items:flex-start}.vtt-toolbar{flex-wrap:wrap;padding:.5rem .75rem}.toolbar-section{flex-wrap:wrap}.token-list{flex-direction:row;overflow-x:auto}.token-list-item{min-width:200px}}button:focus-visible,a:focus-visible,.terrain-button:focus-visible{outline:2px solid #58a6ff;outline-offset:2px}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}@media(prefers-contrast: high){.token-card,.token-list-item,.terrain-button{border-width:2px}.vtt-toolbar{background:#000;border-bottom:2px solid #fff}}@media(prefers-reduced-motion: reduce){.token-card,.token-list-item,.terrain-button,.info-panel-toggle i{transition:none}}@media print{.vtt-toolbar,.vtt-sidebar,.vtt-info-bar,.vtt-info-panel{display:none !important}.vtt-canvas-container{height:100vh}canvas{box-shadow:none}}.vtt-player-view:-webkit-full-screen .vtt-toolbar-minimal,.vtt-player-view:fullscreen .vtt-toolbar-minimal{opacity:0;pointer-events:none;transition:opacity .3s ease}.vtt-player-view:-webkit-full-screen:hover .vtt-toolbar-minimal,.vtt-player-view:fullscreen:hover .vtt-toolbar-minimal{opacity:1;pointer-events:auto}.vtt-loading{display:flex;align-items:center;justify-content:center;min-height:400px}.vtt-loading-spinner{width:3rem;height:3rem;border:3px solid rgba(88, 166, 255, 0.2);border-top-color:#58a6ff;border-radius:50%;animation:vtt-spin .8s linear infinite}@keyframes vtt-spin{to{transform:rotate(360deg)}}[data-tool].active{background-color:#1f6feb !important;border-color:#58a6ff !important;box-shadow:0 0 8px rgba(88, 166, 255, 0.3)}.token-info-card{background:rgba(13, 17, 23, 0.95);border:1px solid #30363d;border-radius:.5rem;padding:1rem;min-width:250px;box-shadow:0 8px 32px rgba(0, 0, 0, 0.5);backdrop-filter:blur(10px)}.token-info-card h6{margin:0 0 .5rem 0;color:#58a6ff;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.token-info-card .stat-row{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.875rem}.token-info-card .stat-label{color:#8b949e}.token-info-card .stat-value{color:#c9d1d9;font-weight:500}.shortcuts-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.shortcuts-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0, 0, 0, 0.85);backdrop-filter:blur(4px)}.shortcuts-modal-content{position:relative;width:90%;max-width:800px;max-height:90vh;background:linear-gradient(135deg, #161b22 0%, #0d1117 100%);border:1px solid #30363d;border-radius:.75rem;box-shadow:0 16px 48px rgba(0, 0, 0, 0.8);overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:#0d1117;border-bottom:1px solid #30363d}.shortcuts-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#c9d1d9;display:flex;align-items:center;gap:.5rem}.shortcuts-header h3 i{color:#58a6ff}.shortcuts-body{padding:1.5rem;overflow-y:auto;max-height:calc(90vh - 180px)}.shortcut-section{background:#0d1117;border:1px solid #30363d;border-radius:.5rem;padding:1rem;height:100%}.shortcut-section-title{margin:0 0 1rem 0;font-size:.875rem;font-weight:600;color:#58a6ff;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem}.shortcut-list{display:flex;flex-direction:column;gap:.75rem}.shortcut-item{display:flex;align-items:center;gap:1rem}.shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;padding:.375rem .75rem;background:linear-gradient(180deg, #21262d 0%, #161b22 100%);border:1px solid #30363d;border-radius:.375rem;font-family:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;font-size:.875rem;font-weight:600;color:#c9d1d9;box-shadow:0 2px 4px rgba(0, 0, 0, 0.3),inset 0 1px 0 rgba(255, 255, 255, 0.1);text-transform:uppercase}.shortcut-item span{color:#8b949e;font-size:.875rem;flex:1}.shortcuts-footer{padding:1rem 1.5rem;background:#0d1117;border-top:1px solid #30363d;text-align:center}.shortcuts-footer i{color:#f0883e}@media(max-width: 768px){.shortcuts-modal-content{width:95%;max-height:95vh}.shortcuts-header{padding:1rem}.shortcuts-header h3{font-size:1rem}.shortcuts-body{padding:1rem;max-height:calc(95vh - 150px)}.shortcut-item{gap:.5rem}.shortcut-item kbd{min-width:2rem;padding:.25rem .5rem;font-size:.75rem}.shortcut-item span{font-size:.8rem}}@media(prefers-reduced-motion: reduce){.shortcuts-modal,.shortcuts-modal-content{animation:none}}.token-palette-section{background:rgba(13, 17, 23, 0.5);border:1px solid #30363d;border-radius:.5rem;padding:.75rem}.token-palette-category{margin-bottom:.5rem}.token-palette-category:last-child{margin-bottom:0}.token-palette-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:.5rem}.token-palette-button{aspect-ratio:1;padding:.25rem;background:rgba(22, 27, 34, 0.8);border:2px solid #30363d;border-radius:.375rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;overflow:hidden}.token-palette-button:hover{border-color:#58a6ff;background:rgba(33, 38, 45, 0.9);transform:scale(1.05);box-shadow:0 0 8px rgba(88, 166, 255, 0.3)}.token-palette-button:active{transform:scale(0.95)}.token-palette-button.selected{border-color:#3fb950;background:rgba(46, 160, 67, 0.1);box-shadow:0 0 8px rgba(63, 185, 80, 0.3)}.token-palette-icon{width:100%;height:100%;object-fit:contain;pointer-events:none}@media(max-width: 1400px){.token-palette-grid{grid-template-columns:repeat(3, 1fr)}}@media(max-width: 768px){.token-palette-grid{grid-template-columns:repeat(4, 1fr)}}:root{--wizard-purple: #d97706;--wizard-purple-dark: #b45309;--wizard-gold: #fbbf24;--wizard-gold-dark: #d4af37;--wizard-parchment: #f4f1e8;--wizard-parchment-dark: #e8e3d3;--wizard-text: #1f2937;--wizard-text-light: #6b7280;--wizard-border: rgba(139, 92, 246, 0.3);--wizard-shadow: 0 4px 12px rgba(0, 0, 0, 0.1)}.wizard-container{max-width:1200px;margin:2rem auto;padding:0 1.5rem;min-height:calc(100vh - 4rem)}.wizard-progress{background:white;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:var(--wizard-shadow);border:2px solid var(--wizard-border)}.progress-steps{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:0 0 auto;min-width:80px}.step-circle{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.75rem;background:#e5e7eb;border:3px solid #d1d5db;transition:all .3s ease}.progress-step.completed .step-circle{background:linear-gradient(135deg, var(--wizard-purple) 0%, var(--wizard-purple-dark) 100%);border-color:var(--wizard-purple);color:white}.progress-step.current .step-circle{background:linear-gradient(135deg, var(--wizard-gold) 0%, var(--wizard-gold-dark) 100%);border-color:var(--wizard-gold-dark);animation:pulse 2s infinite}.progress-step.future .step-circle{background:white;border-color:#d1d5db}@keyframes pulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(251, 191, 36, 0.7)}50%{transform:scale(1.05);box-shadow:0 0 0 10px rgba(251, 191, 36, 0)}}.step-icon{font-size:1.5rem}.step-label{font-size:.75rem;font-weight:600;text-align:center;color:var(--wizard-text-light);text-transform:uppercase;letter-spacing:.5px}.progress-step.completed .step-label,.progress-step.current .step-label{color:var(--wizard-purple)}.progress-connector{flex:1;height:3px;background:#d1d5db;margin:0 .5rem;min-width:20px;transition:background .3s ease}.progress-connector.completed{background:linear-gradient(90deg, var(--wizard-purple) 0%, var(--wizard-purple-dark) 100%)}.wizard-content{background:linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 241, 232, 0.98) 100%);border-radius:16px;padding:3rem;box-shadow:var(--wizard-shadow);border:2px solid var(--wizard-border);position:relative;overflow:hidden}.wizard-content::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg, var(--wizard-purple) 0%, var(--wizard-gold) 100%)}.glassmorphic-content-card{background:rgba(255, 255, 255, 0.95);backdrop-filter:blur(10px);border-radius:12px;padding:1.5rem}.step-header{text-align:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--wizard-border)}.step-title{font-size:2.5rem;font-weight:700;color:var(--wizard-text);margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:1rem}.title-icon{font-size:2rem}.step-description{font-size:1.125rem;color:var(--wizard-text-light);max-width:700px;margin:0 auto;line-height:1.6}.wizard-start{max-width:900px;margin:0 auto}.start-header{text-align:center;margin-bottom:3rem}.start-title{font-size:3rem;font-weight:700;color:var(--wizard-text);margin-bottom:1rem;background:linear-gradient(135deg, var(--wizard-purple) 0%, var(--wizard-gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.start-subtitle{font-size:1.25rem;color:var(--wizard-text-light)}.start-welcome{display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;margin-bottom:3rem;padding:2rem;background:white;border-radius:12px;border:2px solid var(--wizard-border)}.welcome-text h2{font-size:1.75rem;color:var(--wizard-text);margin-bottom:1rem}.welcome-text p{color:var(--wizard-text-light);line-height:1.6;margin-bottom:1rem}.hero-illustration{width:150px;height:150px;border-radius:12px;background:linear-gradient(135deg, var(--wizard-purple) 0%, var(--wizard-gold) 100%);display:flex;align-items:center;justify-content:center;font-size:5rem}.start-steps-preview{margin-bottom:3rem}.start-steps-preview h3{font-size:1.5rem;color:var(--wizard-text);margin-bottom:1.5rem;text-align:center}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem}.step-preview-card{padding:1.5rem;background:white;border-radius:12px;border:2px solid var(--wizard-border);text-align:center;transition:all .3s ease}.step-preview-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(139, 92, 246, 0.2);border-color:var(--wizard-purple)}.step-preview-icon{font-size:2.5rem;margin-bottom:1rem}.step-preview-title{font-size:1rem;font-weight:700;color:var(--wizard-text);margin-bottom:.5rem}.step-preview-desc{font-size:.875rem;color:var(--wizard-text-light);line-height:1.4}.start-features{display:grid;grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));gap:1rem;margin-bottom:3rem}.feature-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:white;border-radius:8px;border:1px solid var(--wizard-border)}.feature-icon{font-size:1.5rem}.feature-text{font-size:.875rem;font-weight:600;color:var(--wizard-text)}.start-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.start-tip{padding:1rem;background:rgba(251, 191, 36, 0.1);border-radius:8px;border:1px solid var(--wizard-gold);text-align:center;color:var(--wizard-text);font-size:.875rem}.tip-icon{font-size:1.25rem;margin-right:.5rem}.race-cards-grid,.class-cards-grid,.background-cards-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));gap:1.5rem}.race-card,.class-card,.background-card{position:relative;cursor:pointer;transition:all .3s ease}.race-radio,.class-radio,.background-radio{position:absolute;opacity:0;pointer-events:none}.race-card-content,.class-card-content,.background-card-content{display:block;padding:1.5rem;background:white;border-radius:12px;border:3px solid transparent;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1);transition:all .3s ease;height:100%}.race-card:hover .race-card-content,.class-card:hover .class-card-content,.background-card:hover .background-card-content{transform:translateY(-4px);box-shadow:0 8px 24px rgba(139, 92, 246, 0.2);border-color:var(--wizard-purple)}.race-card.selected .race-card-content,.class-card.selected .class-card-content,.background-card.selected .background-card-content{border-color:var(--wizard-gold-dark);box-shadow:0 8px 24px rgba(212, 175, 55, 0.3);background:linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(212, 175, 55, 0.05) 100%)}.race-icon{font-size:3rem;text-align:center;margin-bottom:1rem}.race-header{text-align:center;margin-bottom:1rem}.race-name{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin-bottom:.5rem}.race-bonuses{font-size:1rem;font-weight:600;color:var(--wizard-purple);background:rgba(139, 92, 246, 0.1);padding:.25rem .75rem;border-radius:6px;display:inline-block}.race-traits{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;justify-content:center}.trait-badge{font-size:.75rem;padding:.25rem .75rem;background:rgba(139, 92, 246, 0.1);color:var(--wizard-purple);border-radius:12px;font-weight:600}.race-lore{font-size:.875rem;color:var(--wizard-text-light);line-height:1.5;margin-bottom:1rem;text-align:center}.race-speed{text-align:center;font-size:.875rem;font-weight:600;color:var(--wizard-text);padding-top:1rem;border-top:1px solid var(--wizard-border)}.speed-icon{margin-right:.25rem}.class-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.class-icon{font-size:2.5rem}.class-name{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin:0}.class-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.class-stat{padding:.75rem;background:rgba(139, 92, 246, 0.05);border-radius:8px;text-align:center}.stat-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:var(--wizard-text-light);margin-bottom:.25rem}.stat-value{font-size:1rem;font-weight:700;color:var(--wizard-purple)}.class-saves,.class-features{font-size:.875rem;color:var(--wizard-text-light);margin-bottom:1rem}.features-list{margin:.5rem 0 0 1.25rem;padding:0}.features-list li{margin-bottom:.25rem}.class-description{font-size:.875rem;color:var(--wizard-text-light);line-height:1.5;padding-top:1rem;border-top:1px solid var(--wizard-border)}.background-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.background-icon{font-size:2.5rem}.background-name{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin:0}.background-proficiencies{margin-bottom:1rem}.proficiency-group{font-size:.875rem;color:var(--wizard-text-light);margin-bottom:.5rem}.background-feature{font-size:.875rem;color:var(--wizard-purple);background:rgba(139, 92, 246, 0.1);padding:.75rem;border-radius:8px;margin-bottom:1rem}.background-description{font-size:.875rem;color:var(--wizard-text-light);line-height:1.5}.personality-section{margin-top:3rem;padding-top:3rem;border-top:2px solid var(--wizard-border)}.personality-title{font-size:1.75rem;font-weight:700;color:var(--wizard-text);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.personality-description{font-size:1rem;color:var(--wizard-text-light);margin-bottom:2rem}.personality-fields{display:grid;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-label{font-size:1rem;font-weight:600;color:var(--wizard-text);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.label-icon{font-size:1.25rem}.form-control,.form-select{padding:.75rem;border:2px solid var(--wizard-border);border-radius:8px;font-size:1rem;transition:all .3s ease}.form-control:focus,.form-select:focus{outline:none;border-color:var(--wizard-purple);box-shadow:0 0 0 3px rgba(139, 92, 246, 0.1)}.form-text{font-size:.875rem;color:var(--wizard-text-light);margin-top:.25rem}.method-selection{margin-bottom:3rem}.section-title{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin-bottom:1.5rem}.method-tabs{display:grid;grid-template-columns:repeat(4, 1fr);gap:1rem}.method-tab{padding:1.5rem;background:white;border:3px solid transparent;border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center}.method-tab:hover{border-color:var(--wizard-purple);box-shadow:0 4px 12px rgba(139, 92, 246, 0.2)}.method-tab.active{border-color:var(--wizard-gold-dark);background:linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(212, 175, 55, 0.05) 100%);box-shadow:0 4px 12px rgba(212, 175, 55, 0.3)}.method-icon{font-size:2rem;display:block;margin-bottom:.5rem}.method-name{font-size:1.125rem;font-weight:700;color:var(--wizard-text);display:block;margin-bottom:.25rem}.method-desc{font-size:.875rem;color:var(--wizard-text-light);display:block}.ability-method-panel{display:none}.ability-method-panel.active{display:block}.method-explanation{padding:1.5rem;background:rgba(139, 92, 246, 0.05);border-radius:12px;margin-bottom:2rem;border-left:4px solid var(--wizard-purple)}.method-explanation h4{font-size:1.25rem;color:var(--wizard-text);margin-bottom:.75rem}.method-explanation p{color:var(--wizard-text-light);line-height:1.6;margin:0}.standard-array-interface{display:grid;grid-template-columns:1fr 2fr;gap:2rem}.available-scores h5{font-size:1rem;font-weight:700;color:var(--wizard-text);margin-bottom:1rem}.score-pool{display:grid;grid-template-columns:repeat(2, 1fr);gap:.75rem}.score-token{padding:1rem;background:white;border:3px solid var(--wizard-purple);border-radius:12px;text-align:center;font-size:1.5rem;font-weight:700;color:var(--wizard-purple);cursor:pointer;transition:all .3s ease}.score-token:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(139, 92, 246, 0.3)}.score-token.selected{border-color:var(--wizard-gold-dark);background:rgba(251, 191, 36, 0.1);color:var(--wizard-gold-dark)}.score-token.used{background:#e5e7eb;border-color:#9ca3af;color:#9ca3af;cursor:not-allowed;opacity:.5}.ability-assignments{display:grid;gap:1rem}.ability-assignment{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center}.ability-label{font-size:1rem;font-weight:600;color:var(--wizard-text);display:flex;align-items:center;gap:.5rem;min-width:150px}.ability-icon{font-size:1.5rem}.ability-slot{padding:1rem;background:white;border:3px dashed var(--wizard-border);border-radius:12px;text-align:center;cursor:pointer;transition:all .3s ease;min-height:60px;display:flex;align-items:center;justify-content:center}.ability-slot:hover{border-color:var(--wizard-purple);background:rgba(139, 92, 246, 0.05)}.ability-slot.selected{border-color:var(--wizard-gold-dark);background:rgba(251, 191, 36, 0.1)}.slot-value{font-size:1.5rem;font-weight:700;color:var(--wizard-text)}.point-buy-tracker{padding:1.5rem;background:white;border-radius:12px;border:2px solid var(--wizard-border);margin-bottom:2rem;text-align:center}.points-remaining{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.points-label{color:var(--wizard-text-light)}.points-value{color:var(--wizard-purple);font-size:2rem;margin:0 .5rem}.points-total{color:var(--wizard-text-light)}.points-cost-table{font-size:.875rem;color:var(--wizard-text-light)}.point-buy-controls{display:grid;gap:1rem}.point-buy-ability{display:grid;grid-template-columns:200px 1fr;gap:1rem;align-items:center;padding:1rem;background:white;border-radius:12px;border:2px solid var(--wizard-border)}.ability-adjuster{display:flex;align-items:center;justify-content:center;gap:1rem}.ability-value{min-width:120px;text-align:center;font-size:1.5rem;font-weight:700;color:var(--wizard-text)}.ability-modifier{display:block;font-size:.875rem;color:var(--wizard-text-light)}.roll-interface{text-align:center}.rolled-scores{padding:1rem;margin-bottom:2rem}.roll-action{margin-bottom:3rem}.roll-results{display:grid;gap:1rem}.roll-result-item{display:grid;grid-template-columns:200px 1fr;gap:1rem;align-items:center;padding:1rem;background:white;border-radius:12px;border:2px solid var(--wizard-border)}.roll-display{position:relative;min-height:60px;display:flex;align-items:center;justify-content:center}.dice-animation{font-size:1.5rem;animation:roll .5s infinite}@keyframes roll{0%,100%{transform:rotate(0deg)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.roll-value{font-size:2rem;font-weight:700;color:var(--wizard-purple)}.manual-entry-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:1.5rem;margin-bottom:2rem}.manual-entry-field{display:flex;flex-direction:column;gap:.5rem}.manual-input-group{display:flex;flex-direction:column;align-items:center;gap:.5rem}.manual-score-input{width:100%;max-width:150px;font-size:1.5rem !important;font-weight:700;color:var(--wizard-purple);border:2px solid var(--wizard-border);border-radius:8px;padding:.75rem !important}.manual-score-input:focus{border-color:var(--wizard-purple);box-shadow:0 0 0 3px rgba(139, 92, 246, 0.1)}.manual-modifier{font-size:1rem;font-weight:600;color:var(--wizard-text-muted)}.manual-entry-tips{padding:1.5rem;background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(99, 102, 241, 0.05) 100%);border-radius:12px;border:2px solid rgba(139, 92, 246, 0.2)}.manual-entry-tips h5{color:var(--wizard-purple);margin-bottom:1rem;font-size:1rem;font-weight:700}.manual-entry-tips ul{margin:0;padding-left:1.5rem}.manual-entry-tips li{margin-bottom:.5rem;color:var(--wizard-text)}.racial-bonus-preview{margin-top:3rem;padding:1.5rem;background:linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(212, 175, 55, 0.05) 100%);border-radius:12px;border:2px solid var(--wizard-gold)}.racial-bonus-preview h4{font-size:1.25rem;color:var(--wizard-text);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.bonus-list{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.bonus-item{padding:.75rem 1.25rem;background:white;border-radius:8px;border:2px solid var(--wizard-gold);display:flex;align-items:center;gap:.75rem}.bonus-ability{font-weight:600;color:var(--wizard-text)}.bonus-value{font-weight:700;color:var(--wizard-gold-dark);font-size:1.125rem}.equipment-choice-group{margin-bottom:3rem}.choice-group-title{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.choice-icon{font-size:1.75rem}.equipment-options{display:grid;gap:1rem}.equipment-option{position:relative}.equipment-radio{position:absolute;opacity:0;pointer-events:none}.equipment-option-label{display:block;padding:1.5rem;background:white;border:3px solid transparent;border-radius:12px;cursor:pointer;transition:all .3s ease}.equipment-option-label:hover{border-color:var(--wizard-purple);box-shadow:0 4px 12px rgba(139, 92, 246, 0.2)}.equipment-radio:checked+.equipment-option-label{border-color:var(--wizard-gold-dark);background:linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(212, 175, 55, 0.05) 100%);box-shadow:0 4px 12px rgba(212, 175, 55, 0.3)}.option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.option-name{font-size:1.125rem;font-weight:700;color:var(--wizard-text)}.option-check{font-size:1.5rem;color:var(--wizard-gold-dark);opacity:0;transition:opacity .3s ease}.equipment-radio:checked+.equipment-option-label .option-check{opacity:1}.option-items{display:flex;flex-wrap:wrap;gap:.75rem}.item-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(139, 92, 246, 0.1);border-radius:8px;font-size:.875rem;font-weight:600;color:var(--wizard-purple)}.item-icon{font-size:1.125rem}.equipment-summary{margin-top:3rem;padding:2rem;background:white;border-radius:12px;border:2px solid var(--wizard-border)}.summary-title{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.summary-items{display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:1rem}.summary-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(139, 92, 246, 0.05);border-radius:8px}.summary-icon{font-size:1.5rem}.summary-name{font-weight:600;color:var(--wizard-text)}.spell-selection-summary{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem;margin-bottom:2rem}.spell-counter{padding:1.5rem;background:white;border-radius:12px;border:2px solid var(--wizard-border);text-align:center}.counter-label{font-size:.875rem;font-weight:600;text-transform:uppercase;color:var(--wizard-text-light);margin-bottom:.5rem}.counter-value{font-size:2rem;font-weight:700;color:var(--wizard-purple)}.spell-filters{display:grid;grid-template-columns:2fr 1fr;gap:1rem;margin-bottom:2rem}.spell-level-section{margin-bottom:3rem}.spell-level-title{font-size:1.5rem;font-weight:700;color:var(--wizard-text);margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}.level-icon{font-size:1.75rem}.spell-level-desc{font-size:1rem;color:var(--wizard-text-light);margin-bottom:1.5rem}.spell-cards-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));gap:1.5rem}.spell-card{position:relative;cursor:pointer;transition:all .3s ease}.spell-checkbox{position:absolute;opacity:0;pointer-events:none}.spell-card-content{display:block;padding:1.5rem;background:white;border:3px solid transparent;border-radius:12px;box-shadow:0 2px 8px rgba(0, 0, 0, 0.1);transition:all .3s ease;height:100%}.spell-card:hover .spell-card-content{transform:translateY(-4px);box-shadow:0 8px 24px rgba(139, 92, 246, 0.2);border-color:var(--wizard-purple)}.spell-card.selected .spell-card-content{border-color:var(--wizard-gold-dark);box-shadow:0 8px 24px rgba(212, 175, 55, 0.3);background:linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(212, 175, 55, 0.05) 100%)}.spell-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.spell-icon{font-size:2rem}.spell-name{font-size:1.125rem;font-weight:700;color:var(--wizard-text);margin:0}.spell-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.spell-school{font-size:.75rem;font-weight:600;padding:.25rem .75rem;background:rgba(139, 92, 246, 0.1);color:var(--wizard-purple);border-radius:12px;text-transform:capitalize}.spell-tag{font-size:.75rem;font-weight:600;padding:.25rem .75rem;border-radius:12px}.ritual-tag{background:rgba(59, 130, 246, 0.1);color:#2563eb}.concentration-tag{background:rgba(239, 68, 68, 0.1);color:#dc2626}.spell-details{font-size:.875rem;color:var(--wizard-text-light);margin-bottom:1rem}.spell-detail-item{margin-bottom:.25rem}.spell-description{font-size:.875rem;color:var(--wizard-text-light);line-height:1.5;border-top:1px solid var(--wizard-border);padding-top:1rem}.spell-limit-alert{animation:slideIn .3s ease}@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}.review-section{margin-bottom:3rem;padding:2rem;background:white;border-radius:12px;border:2px solid var(--wizard-border)}.character-identity-section{background:linear-gradient(135deg, rgba(139, 92, 246, 0.05) 0%, rgba(236, 72, 153, 0.05) 100%)}.identity-fields{display:grid;gap:1.5rem}.required-field label::after{content:" *";color:#dc2626}.identity-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:1rem}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:1.5rem}.summary-card{padding:1.5rem;background:white;border-radius:12px;border:2px solid var(--wizard-border)}.summary-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid var(--wizard-border)}.summary-card-header h3{font-size:1.125rem;font-weight:700;color:var(--wizard-text);margin:0}.summary-icon{font-size:1.75rem}.summary-value{font-size:1.5rem;font-weight:700;color:var(--wizard-purple);margin-bottom:.5rem}.summary-detail{font-size:.875rem;color:var(--wizard-text-light);margin-bottom:1rem}.abilities-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(120px, 1fr));gap:1rem}.ability-summary-card{padding:1rem;background:white;border-radius:12px;border:2px solid var(--wizard-border);text-align:center}.ability-summary-card .ability-name{font-size:.875rem;font-weight:700;text-transform:uppercase;color:var(--wizard-text-light);margin-bottom:.5rem}.ability-scores{margin-bottom:.5rem}.base-score{font-size:1rem;color:var(--wizard-text-light)}.racial-bonus{color:var(--wizard-gold-dark);font-weight:700}.final-score{font-size:2rem;font-weight:700;color:var(--wizard-text)}.ability-summary-card .ability-modifier{font-size:1.25rem;font-weight:700;padding:.25rem .75rem;border-radius:8px;display:inline-block}.ability-summary-card .ability-modifier.positive{color:#059669;background:rgba(5, 150, 105, 0.1)}.ability-summary-card .ability-modifier.negative{color:#dc2626;background:rgba(220, 38, 38, 0.1)}.equipment-list{display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:1rem}.equipment-item-review{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(139, 92, 246, 0.05);border-radius:8px}.spell-group{margin-bottom:2rem}.spell-group-title{font-size:1.125rem;font-weight:700;color:var(--wizard-text);margin-bottom:1rem}.spell-list-review{display:grid;grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));gap:.75rem}.spell-item-review{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(139, 92, 246, 0.05);border-radius:8px}.personality-items{display:grid;gap:1rem}.personality-item{padding:1rem;background:white;border-radius:8px;border-left:4px solid var(--wizard-purple)}.review-final-actions{margin:3rem 0 2rem}.wizard-navigation{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:3rem;padding-top:2rem;border-top:2px solid var(--wizard-border)}.btn{padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:1rem;border:none;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn-primary{background:linear-gradient(135deg, var(--wizard-purple) 0%, var(--wizard-purple-dark) 100%);color:white;box-shadow:0 4px 12px rgba(139, 92, 246, 0.3)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(139, 92, 246, 0.4)}.wizard-btn-primary{background:linear-gradient(135deg, var(--wizard-purple) 0%, var(--wizard-gold) 100%);font-size:1.125rem;padding:1rem 2rem}.wizard-btn-final{background:linear-gradient(135deg, #059669 0%, #047857 100%);font-size:1.25rem;padding:1.25rem 2.5rem;box-shadow:0 4px 12px rgba(5, 150, 105, 0.3)}.wizard-btn-final:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(5, 150, 105, 0.4)}.btn-secondary{background:white;color:var(--wizard-text);border:2px solid var(--wizard-border)}.btn-secondary:hover{border-color:var(--wizard-purple);background:rgba(139, 92, 246, 0.05)}.btn-success{background:linear-gradient(135deg, #059669 0%, #047857 100%);color:white;box-shadow:0 4px 12px rgba(5, 150, 105, 0.3)}.btn-success:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(5, 150, 105, 0.4)}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-outline-secondary{background:transparent;border:2px solid var(--wizard-border);color:var(--wizard-text)}.btn-outline-secondary:hover{border-color:var(--wizard-purple);background:rgba(139, 92, 246, 0.05)}.btn-icon{font-size:1.25rem}.btn-arrow{font-size:1.25rem}.float-end{float:right}@media(max-width: 1024px){.race-cards-grid,.class-cards-grid,.background-cards-grid,.spell-cards-grid{grid-template-columns:1fr}.standard-array-interface{grid-template-columns:1fr}.method-tabs{grid-template-columns:1fr}.spell-filters{grid-template-columns:1fr}}@media(max-width: 768px){.wizard-content{padding:2rem 1.5rem}.step-title{font-size:2rem}.progress-steps{flex-wrap:wrap}.progress-step{min-width:60px}.step-circle{width:50px;height:50px;font-size:1.5rem}.start-welcome{grid-template-columns:1fr}.hero-illustration{width:120px;height:120px;margin:0 auto}.point-buy-ability{grid-template-columns:1fr}.roll-result-item{grid-template-columns:1fr}.manual-entry-grid{grid-template-columns:1fr}.summary-grid,.abilities-grid{grid-template-columns:1fr}.wizard-navigation{flex-direction:column-reverse}.wizard-navigation .btn{width:100%;justify-content:center}}@media(max-width: 480px){.wizard-container{padding:0 1rem}.wizard-content{padding:1.5rem 1rem}.step-title{font-size:1.5rem}.start-title{font-size:2rem}.progress-step{min-width:50px}.step-circle{width:40px;height:40px;font-size:1.25rem}.step-label{font-size:.625rem}.method-tabs{gap:.5rem}.ability-adjuster{flex-direction:column}}.text-muted{color:var(--wizard-text-light)}.text-success{color:#059669}.text-center{text-align:center}.alert{padding:1rem;border-radius:8px;margin-bottom:1rem}.alert-warning{background:rgba(251, 191, 36, 0.1);border:1px solid var(--wizard-gold);color:var(--wizard-text)}.alert-info{background:rgba(59, 130, 246, 0.1);border:1px solid #3b82f6;color:var(--wizard-text)}.alert-success{background:rgba(5, 150, 105, 0.1);border:1px solid #059669;color:var(--wizard-text)}.alert h4{font-size:1.25rem;margin-bottom:.5rem}.alert p{margin:0;line-height:1.6}.feat-selector{margin:2rem 0}.feat-selector-header h4{color:var(--wizard-purple);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.feat-icon{font-size:1.5rem}.feat-selection-count{text-align:center}.feat-selection-count .badge{font-size:1rem;padding:.5rem 1rem}.feat-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(350px, 1fr));gap:1.5rem;margin-top:1.5rem}.feat-card{background:white;border:3px solid var(--wizard-border);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative}.feat-card:hover{border-color:var(--wizard-purple);box-shadow:0 4px 12px rgba(139, 92, 246, 0.2);transform:translateY(-2px)}.feat-card.selected{border-color:var(--wizard-gold-dark);background:linear-gradient(135deg, rgba(251, 191, 36, 0.05) 0%, rgba(212, 175, 55, 0.05) 100%);box-shadow:0 4px 12px rgba(212, 175, 55, 0.3)}.feat-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.feat-name{font-size:1.25rem;font-weight:700;color:var(--wizard-purple);margin:0;flex:1}.feat-select-indicator{font-size:1.5rem;color:var(--wizard-gold-dark);opacity:0;transition:opacity .3s ease}.feat-card.selected .feat-select-indicator{opacity:1}.feat-prerequisites{margin-bottom:1rem;padding:.5rem;background:rgba(251, 191, 36, 0.1);border-left:3px solid #f59e0b;border-radius:4px}.feat-asi{padding:.75rem;background:rgba(16, 185, 129, 0.1);border-left:3px solid #10b981;border-radius:4px;font-size:.875rem}.feat-description{color:var(--wizard-text);font-size:.9rem;line-height:1.6;margin-bottom:1rem}.feat-benefits{font-size:.875rem}.benefit-category{margin-bottom:.75rem}.benefit-list{margin:.25rem 0 0 1.5rem;padding:0;color:var(--wizard-text)}.benefit-list li{margin-bottom:.25rem}.feat-details-btn{transition:all .2s}.feat-details-btn:hover{transform:scale(1.02)}.feat-full-description{line-height:1.8;color:#333}.feat-full-description p{margin-bottom:1rem}@media(max-width: 768px){.feat-grid{grid-template-columns:1fr}.feat-card{padding:1rem}.feat-name{font-size:1.1rem}}
