@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8d697b304b401681-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba015fad6dcf6784-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/4cf2300e9c8272f7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Fallback;src:local("Arial");ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.00%;size-adjust:104.76%}.__className_188709{font-family:Geist,Geist Fallback;font-style:normal}.__variable_188709{--font-geist-sans:"Geist","Geist Fallback"}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/9610d9e46709d722-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/747892c23ea88013-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/93f479601ee12b01-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Mono Fallback;src:local("Arial");ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.00%;size-adjust:134.59%}.__className_9a8899{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.__variable_9a8899{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}

/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-space-x-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-outline-style:solid}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-500:oklch(63.7% .237 25.331);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--font-weight-semibold:600;--font-weight-bold:700;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.mt-2{margin-top:calc(var(--spacing)*2)}.ml-2{margin-left:calc(var(--spacing)*2)}.flex{display:flex}.grid{display:grid}.table{display:table}.items-center{align-items:center}:where(.space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}.border{border-style:var(--tw-border-style);border-width:1px}.py-4{padding-block:calc(var(--spacing)*4)}.text-center{text-align:center}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-red-500{color:var(--color-red-500)}.italic{font-style:italic}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#e2e8f0;--fg-primary:#1e293b;--fg-secondary:#475569;--fg-tertiary:#64748b;--accent-primary:#3b82f6;--accent-secondary:#6366f1;--border-color:#e2e8f0;--shadow-color:#0000001a;--shadow-color-accent:#3b82f633;--error-color:#ef4444;--success-color:#10b981}@media (prefers-color-scheme:dark){:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--fg-primary:#f1f5f9;--fg-secondary:#cbd5e1;--fg-tertiary:#94a3b8;--accent-primary:#60a5fa;--accent-secondary:#818cf8;--border-color:#334155;--shadow-color:#0000004d;--shadow-color-accent:#60a5fa33;--error-color:#f87171;--success-color:#34d399}}*{box-sizing:border-box}body,html{height:100%;margin:0;padding:0}body{color:var(--fg-primary);font-family:Arial,Helvetica,sans-serif;transition:background-color .3s,color .3s}.app-container,body{background:var(--bg-primary)}.app-container{flex-direction:column;min-height:100vh;display:flex}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color);align-items:center;height:64px;padding:1rem 1.5rem;display:flex}.main-content{background:var(--bg-primary);justify-content:center;align-items:center;overflow-y:auto}.navbar-content{justify-content:space-between;align-items:center;width:100%;max-width:80rem;margin:0 auto;display:flex}.hero-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem}.hero-grid{grid-template-columns:1fr 1fr;align-items:center;gap:4rem;min-height:60vh;display:grid}.hero-content{flex-direction:column;justify-content:center;display:flex}.hero-text{max-width:500px}.hero-title{color:var(--fg-primary);margin-bottom:1.5rem;font-size:3.5rem;font-weight:800;line-height:1.1}.hero-brand{color:var(--accent-primary);margin-top:.5rem;display:block}.hero-description{color:var(--fg-tertiary);max-width:450px;margin-bottom:2.5rem;font-size:1.25rem;line-height:1.6}.hero-actions{flex-direction:column;gap:2rem;display:flex}.hero-button{align-self:flex-start;padding:1rem 2.5rem;font-size:1.125rem}.hero-stats{gap:2rem;display:flex}.stat-item{text-align:center}.stat-number{color:var(--accent-primary);font-size:2rem;font-weight:700;line-height:1}.stat-label{color:var(--fg-tertiary);margin-top:.25rem;font-size:.875rem}.hero-visual{justify-content:center;align-items:center;display:flex}.visual-container{width:100%;max-width:400px;position:relative}.visual-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;display:grid}.visual-item{aspect-ratio:1;opacity:.8;border-radius:.75rem;transition:all .3s}.visual-item:hover{opacity:1;transform:scale(1.05)}.visual-text{flex-direction:column;gap:.5rem;font-size:1.5rem;font-weight:600}.auth-container,.visual-text{align-items:center;display:flex}.auth-container{background:var(--bg-primary);justify-content:center;width:100%;min-height:100vh;padding:2rem}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-color);width:100%;max-width:450px;box-shadow:0 10px 25px var(--shadow-color);border-radius:1rem;padding:2.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-title{color:var(--fg-primary);margin-bottom:.5rem;font-size:2rem;font-weight:700}.auth-subtitle{color:var(--fg-tertiary);font-size:1rem}.auth-form{flex-direction:column;gap:1.5rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{font-size:.875rem;font-weight:600}.form-input{border-radius:.5rem;padding:.75rem 1rem}.form-hint{color:var(--fg-tertiary);margin-top:.25rem;font-size:.75rem}.auth-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600}.auth-error{border:1px solid var(--error-color);color:var(--error-color);background:#ef44441a;border-radius:.5rem}.auth-error,.auth-success{padding:.75rem 1rem;font-size:.875rem}.auth-success{border:1px solid var(--success-color);color:var(--success-color);background:#10b9811a;border-radius:.5rem}.auth-footer{text-align:center;flex-direction:column;gap:.75rem;margin-top:2rem;display:flex}.auth-footer-text{color:var(--fg-tertiary);font-size:.875rem}.dashboard-container{background:var(--bg-primary);width:100%;min-height:calc(100vh - 64px);padding:2rem}.dashboard-content{max-width:1200px;margin:0 auto}.dashboard-header{text-align:center;margin-bottom:3rem}.dashboard-title{color:var(--fg-primary);margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.dashboard-subtitle{color:var(--fg-tertiary);font-size:1.125rem}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;display:grid}.dashboard-card{background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 4px 6px var(--shadow-color);border-radius:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.dashboard-card:hover{box-shadow:0 8px 12px var(--shadow-color);transform:translateY(-2px)}.card-title{color:var(--fg-primary);border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:600}.card-content{color:var(--fg-secondary);line-height:1.6}.stat-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.stat-row:last-child{border-bottom:none}.stat-value{color:var(--accent-primary);font-weight:600}.game-item{text-align:center;padding:1rem 0}.game-title{color:var(--fg-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.game-description{color:var(--fg-secondary);margin-bottom:1.5rem;line-height:1.5}@media (max-width:768px){.hero-grid{text-align:center;grid-template-columns:1fr;gap:2rem}.hero-title{font-size:2.5rem}.hero-actions{align-items:center}.hero-button{align-self:center}.hero-stats{justify-content:center}.visual-container{max-width:300px}.auth-card{padding:2rem}.form-row{grid-template-columns:1fr}.dashboard-container{padding:1rem}.dashboard-title{font-size:2rem}.dashboard-grid{grid-template-columns:1fr;gap:1rem}}.bg-primary{background-color:var(--bg-primary)!important}.bg-secondary{background-color:var(--bg-secondary)!important}.bg-tertiary{background-color:var(--bg-tertiary)!important}.text-primary{color:var(--fg-primary)!important}.text-secondary{color:var(--fg-secondary)!important}.text-tertiary{color:var(--fg-tertiary)!important}.text-accent{color:var(--accent-primary)!important}.border-color{border-color:var(--border-color)!important}.shadow-default{box-shadow:0 4px 6px var(--shadow-color)!important}.shadow-accent{box-shadow:0 4px 6px var(--shadow-color-accent)!important}.btn-primary{background:var(--accent-primary);color:#fff;cursor:pointer;text-align:center;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.btn-primary:hover{background:var(--accent-secondary);box-shadow:0 4px 8px var(--shadow-color-accent);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-tertiary);color:var(--fg-primary);border:1px solid var(--border-color);cursor:pointer;text-align:center;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--accent-primary)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.card{background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color);border-radius:.5rem;padding:1rem}.link{color:var(--accent-primary);text-decoration:none;transition:color .2s}.link:hover{color:var(--accent-secondary)}.quest-container{background:var(--bg-primary);min-height:100vh;padding:2rem}.quest-content{max-width:1400px;margin:0 auto}.quest-header{margin-bottom:2rem}.quest-title{margin-bottom:.5rem;font-size:2.5rem}.quest-subtitle{font-size:1.1rem}.quest-layout{grid-template-columns:1fr 400px;gap:2rem;min-height:600px;display:grid}.quest-main-area{padding:2rem}.quest-main-area,.quest-sidebar{background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-color);border-radius:12px}.quest-sidebar{height:fit-content;padding:1.5rem}.sidebar-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.sidebar-title{color:var(--fg-primary);font-size:1.25rem;font-weight:600}.character-list{flex-direction:column;gap:1rem;display:flex}.character-card{background:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;padding:1rem;transition:all .2s}.character-card.selected,.character-card:hover{border-color:var(--accent-primary);box-shadow:0 2px 4px var(--shadow-color-accent)}.character-card.selected{background:var(--shadow-color-accent)}.character-card-name{color:var(--fg-primary);margin:0;font-size:1rem;font-weight:600}.character-card-level{color:var(--accent-primary);font-size:.875rem;font-weight:600}.character-card-details{flex-direction:column;gap:.25rem;margin-bottom:.5rem;display:flex}.character-card-traits{flex-wrap:wrap;gap:.25rem;display:flex}.character-card-location-row{display:flex}.character-card-ancestry,.character-card-class{color:var(--fg-tertiary);background:var(--bg-tertiary);border-radius:.25rem;padding:.125rem .375rem;font-size:.75rem;display:inline-block}.character-card-location{color:var(--fg-secondary);font-size:.75rem;font-style:italic;display:inline-block}.character-card-location.loading{color:var(--accent-primary);opacity:.7;font-style:italic}.character-card-health{align-items:center;gap:.5rem;display:flex}.health-bar{border-radius:3px;flex:1;height:6px}.health-text{text-align:right;min-width:40px}.quest-welcome{justify-content:center;align-items:center;height:100%;min-height:400px;display:flex}.welcome-content{text-align:center;max-width:400px}.welcome-title{color:var(--fg-primary);margin-bottom:1rem;font-size:1.5rem;font-weight:600}.welcome-text{color:var(--fg-secondary);margin-bottom:2rem;line-height:1.6}.welcome-actions{justify-content:center;display:flex}.character-details{height:100%;padding:2rem}.character-header{border-bottom:1px solid var(--border-color);justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.character-info-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:2rem;display:grid}.info-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem}.info-section-title{color:var(--fg-primary);border-bottom:1px solid var(--border-color);margin:0 0 1rem;padding-bottom:.5rem;font-size:1.1rem;font-weight:600}.info-row{border-bottom:1px solid var(--bg-tertiary);justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.info-row:last-child{border-bottom:none}.info-label{color:var(--fg-secondary);font-size:.9rem;font-weight:500}.info-value{color:var(--fg-primary);font-size:.9rem;font-weight:600}.attributes-grid{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.attribute-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;align-items:center;padding:.75rem;display:flex}.attribute-label{color:var(--fg-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:600}.attribute-value{color:var(--accent-primary);margin-top:.25rem;font-size:1.25rem;font-weight:700}.character-actions{border-top:1px solid var(--border-color);flex-wrap:wrap;gap:1rem;padding-top:1rem;display:flex}.character-form{max-width:600px}.form-section{margin-bottom:2rem}.form-section-title{color:var(--fg-primary);border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.25rem;font-weight:600}.form-group{margin-bottom:1rem}.form-label{color:var(--fg-primary);margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.form-input{border:1px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--fg-primary);border-radius:8px;padding:.75rem;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--shadow-color-accent);outline:none}.form-input::placeholder{color:var(--fg-tertiary)}.form-actions{border-top:1px solid var(--border-color);gap:1rem;margin-top:2rem;padding-top:1rem;display:flex}.description-sections{flex-direction:column;gap:1.5rem;display:flex}.description-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem}.description-title{color:var(--fg-primary);margin-bottom:.5rem;font-size:1rem;font-weight:600}.description-text{color:var(--fg-secondary);font-size:.9rem;line-height:1.6}@media (max-width:768px){.quest-layout{grid-template-columns:1fr;gap:1rem}.quest-container{padding:1rem}.quest-title{font-size:2rem}.character-actions,.form-actions{flex-direction:column}}.delete-btn{color:var(--error-color);cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:1.2rem;font-weight:700;transition:all .2s}.delete-btn:hover{opacity:1}.btn-danger,.delete-btn:hover{background-color:var(--error-color);color:#fff}.btn-danger{border:1px solid var(--error-color);cursor:pointer;border-radius:.375rem;justify-content:center;align-items:center;min-height:2.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.btn-danger:hover{background-color:#dc2626;border-color:#dc2626;transform:translateY(-1px);box-shadow:0 4px 6px #ef444433}.btn-danger:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-primary);box-shadow:0 10px 25px var(--shadow-color);border:1px solid var(--border-color);border-radius:.5rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);padding:1.5rem 1.5rem 1rem}.modal-title{color:var(--fg-primary);margin:0;font-size:1.25rem;font-weight:600}.modal-body{color:var(--fg-secondary);padding:1.5rem;line-height:1.6}.modal-body p{margin:0 0 1rem}.modal-body p:last-child{margin-bottom:0}.modal-actions{justify-content:flex-end;gap:.75rem;padding:0 1.5rem 1.5rem;display:flex}.modal-actions .btn-secondary{margin-right:auto}.character-card-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex;position:relative}.character-card-header .delete-btn{opacity:0;transition:opacity .2s;position:absolute;top:0;right:0}.character-card:hover .delete-btn{opacity:.7}.character-card:hover .delete-btn:hover{opacity:1}.quest-play-container{background:var(--bg-primary);flex-direction:column;gap:.5rem;width:100vw;padding:.5rem;display:flex}.main-content{flex:1;min-height:0;overflow:hidden}.left-column,.main-content{align-items:flex-start;gap:.5rem;display:flex}.left-column{flex-direction:column;width:300px}.char-widget-panel{height:fit-content;padding:.75rem}.bottom-left-panel,.char-widget-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;width:100%}.bottom-left-panel{overflow:hidden}.bottom-left-panel,.center-column{flex-direction:column;display:flex}.center-column{flex:1;align-items:flex-start;gap:.5rem}.node-name-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;justify-content:center;align-items:center;width:100%;height:fit-content;padding:.75rem 1rem;display:flex}.main-panel{flex:1;width:100%}.main-panel,.right-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;overflow-y:auto}.right-panel{flex-direction:column;align-self:flex-start;gap:1rem;width:320px;display:flex}.footer-row{gap:.5rem;display:flex}.bottom-middle-panel{flex:1;justify-content:center}.bottom-middle-panel,.bottom-right-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.5rem;align-items:center;padding:.75rem 1rem;display:flex}.bottom-right-panel{justify-content:flex-end;gap:.5rem}.character-info{align-items:center;gap:1rem;display:flex}.character-header{align-items:center;gap:.75rem;display:flex}.character-name{color:var(--fg-primary);margin:0;font-size:1.125rem;font-weight:600}.character-level{color:var(--accent-primary);background:var(--bg-tertiary);border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.health-bar-container{align-items:center;gap:.5rem;min-width:120px;display:flex}.health-bar{background:var(--bg-tertiary);border-radius:.25rem;width:80px;height:.5rem;overflow:hidden}.health-fill{background:linear-gradient(90deg,#ef4444,#f97316);height:100%;transition:width .3s}.health-text{color:var(--fg-secondary);white-space:nowrap;font-size:.75rem}.status-effects{gap:.25rem;display:flex}.location-info{gap:1rem}.location-info,.system-time{align-items:center;display:flex}.system-time{color:var(--fg-secondary);gap:.25rem;font-size:.875rem}.time-emoji{font-size:1rem}.current-location{align-items:center;gap:.5rem;display:flex}.location-title{color:var(--fg-primary);margin:0;font-size:.875rem;font-weight:600}.connected-nodes{gap:.5rem}.node-link{gap:.25rem;padding:.25rem .5rem;font-size:.75rem;transition:background-color .2s}.node-link:hover{color:#fff}.quests-title{color:var(--fg-primary);margin:0;font-size:1rem;font-weight:600}.quests-refreshing{opacity:.7;font-size:.875rem;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.chat-window{flex-direction:column;height:100%;display:flex}.chat-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.75rem;display:flex}.channel-selector{gap:.25rem;display:flex}.channel-btn{background:var(--bg-tertiary);color:var(--fg-secondary);cursor:pointer;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;transition:all .2s}.channel-btn.active{background:var(--accent-primary);color:#fff}.chat-messages{flex-direction:column;flex:1;gap:.5rem;padding:.75rem;display:flex;overflow-y:auto}.chat-message{gap:.5rem;font-size:.875rem;line-height:1.4;display:flex}.message-time{color:var(--fg-tertiary);min-width:2.5rem;font-size:.75rem}.message-sender{color:var(--accent-primary);font-weight:500}.message-text{color:var(--fg-secondary)}.chat-input{border-top:1px solid var(--border-color);gap:.5rem;padding:.75rem;display:flex}.chat-input-field{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--fg-primary);border-radius:.25rem;flex:1;padding:.5rem;font-size:.875rem}.chat-input-field:focus{border-color:var(--accent-primary);outline:none}.chat-send-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:.25rem;padding:.5rem;transition:background-color .2s}.chat-send-btn:hover{background:var(--accent-secondary)}.chat-send-btn:disabled{background:var(--fg-tertiary);cursor:not-allowed}.connection-status{align-items:center;gap:.5rem;font-size:.75rem;display:flex}.connection-indicator{font-size:.75rem}.connection-indicator.connected{color:var(--success-color)}.connection-indicator.connecting{color:#f59e0b}.connection-indicator.error{color:var(--error-color)}.connection-indicator.disconnected{color:var(--fg-tertiary)}.status-text{color:var(--fg-secondary);font-size:.75rem}.retry-btn{background:0 0;border-radius:.125rem;padding:.125rem;font-size:.75rem}.quests-panel{flex-direction:column;gap:1rem;display:flex}.connected-nodes-section{margin-bottom:1rem}.nodes-title{color:var(--fg-primary);margin:0 0 .5rem;font-size:1rem;font-weight:600}.connected-nodes{flex-direction:column;gap:.25rem;display:flex}.node-link{background:var(--bg-tertiary);cursor:pointer;border-radius:.25rem;align-items:center;gap:.5rem;padding:.5rem;transition:all .2s;display:flex}.node-link:hover{background:var(--accent-primary);transform:translate(2px)}.node-emoji{font-size:1rem}.node-name{color:var(--fg-primary);font-size:.875rem}.direction-arrow{color:var(--accent-primary);font-size:.875rem;font-weight:700}.no-connections{background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:.25rem;justify-content:center;align-items:center;padding:1rem;display:flex}.no-connections-text{color:var(--fg-tertiary);font-size:.875rem;font-style:italic}.quests-list{gap:.5rem}.quest-item,.quests-list{flex-direction:column;display:flex}.quest-item{background:var(--bg-tertiary);border-left:3px solid #0000;border-radius:.5rem;margin-bottom:.25rem;padding:.5rem}.quest-item.active{border-left-color:var(--accent-primary)}.quest-item.available{border-left-color:var(--success-color)}.quest-item.completed{border-left-color:var(--fg-tertiary);opacity:.7}.quest-item.main{border-left-color:#f97316}.quest-item.side{border-left-color:#eab308}.quest-emoji{font-size:1rem}.quest-title{font-size:.875rem;font-weight:600}.quest-status{color:var(--fg-tertiary);text-transform:capitalize;font-size:.75rem}.quest-header{flex-direction:column;align-items:flex-start;width:100%;margin-bottom:.25rem;display:flex}.quest-description{color:var(--fg-secondary);margin-bottom:.5rem;font-size:.75rem;font-style:italic;line-height:1.4}.quest-tasks{margin-top:0;padding-top:0}.tasks-list{margin:0;padding:0;list-style:none}.task-item{color:var(--fg-tertiary);padding:.25rem 0 .25rem 1rem;font-size:.75rem;position:relative}.task-item:before{content:"•";color:var(--accent-primary);font-weight:700;position:absolute;left:0}.action-buttons{gap:.5rem;display:flex}.action-btn{background:var(--bg-tertiary);cursor:pointer;border:none;border-radius:.25rem;justify-content:center;align-items:center;padding:.75rem;font-size:1.25rem;transition:all .2s;display:flex}.action-btn:hover{background:var(--accent-primary);transform:translateY(-1px)}.key-abilities{flex-direction:column;gap:.5rem;display:flex}.abilities-title{color:var(--fg-primary);text-align:center;margin:0;font-size:.875rem;font-weight:600}.abilities-grid{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.ability-btn{background:var(--bg-tertiary);cursor:pointer;border:none;border-radius:.25rem;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;transition:all .2s;display:flex}.ability-btn:hover{background:var(--accent-primary);transform:translateY(-1px)}.ability-key{color:var(--fg-tertiary);font-size:.75rem;font-weight:600}.ability-emoji{font-size:1rem}.ability-name{color:var(--fg-secondary);font-size:.75rem}.main-area{flex-direction:column;gap:1rem;height:100%;display:flex}.area-header{border-bottom:1px solid var(--border-color);padding-bottom:1rem}.area-title{color:var(--fg-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.area-description{color:var(--fg-secondary);margin:0;font-size:.875rem;line-height:1.5}.area-content{flex-direction:column;flex:1;gap:1rem;display:flex}.section-title{color:var(--fg-primary);margin:0 0 .5rem;font-size:1rem;font-weight:600}.features-list,.npcs-list{flex-direction:column;gap:.5rem;display:flex}.feature-item,.npc-item{background:var(--bg-tertiary);border-radius:.25rem;align-items:center;gap:.5rem;padding:.5rem;transition:background-color .2s;display:flex}.feature-item:hover,.npc-item:hover{background:var(--accent-primary);color:#fff}.feature-emoji,.npc-emoji{font-size:1rem}.feature-name,.npc-name{color:var(--fg-primary);flex:1;font-size:.875rem}.npc-info{flex-direction:column;flex:1;gap:.125rem;display:flex}.npc-tag{color:var(--fg-tertiary);font-size:.75rem;font-style:italic}.npc-actions{align-items:center;gap:.25rem;display:flex}.traveling-indicator{font-size:.75rem;animation:spin 1s linear infinite}.travel-error{background:#ef44441a;border:1px solid #ef4444;border-radius:.25rem;justify-content:space-between;align-items:center;margin-top:.5rem;padding:.5rem;display:flex}.error-text{color:#ef4444;font-size:.875rem}.dismiss-btn{color:#ef4444;background:0 0;padding:.25rem;font-size:1rem}.dismiss-btn:hover{color:#dc2626}.loading-spinner{justify-content:center;align-items:center;font-size:2rem;animation:spin 1s linear infinite;display:flex}.retry-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:.25rem;padding:.5rem 1rem;font-size:.875rem;transition:background-color .2s}.retry-btn:hover{background:var(--accent-secondary)}.optimistic-update{opacity:.8;position:relative}.optimistic-update:after{content:"🔄";color:var(--accent-primary);font-size:.75rem;animation:spin 1s linear infinite;position:absolute;top:.5rem;right:.5rem}.optimistic-indicator{color:var(--accent-primary);font-size:.875rem;font-style:italic;font-weight:400}.no-npcs{color:var(--fg-tertiary);justify-content:center;align-items:center;padding:1rem;font-style:italic;display:flex}.interact-btn,.no-npcs-text,.quest-indicator{font-size:.875rem}.interact-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:.25rem;padding:.25rem .5rem;transition:background-color .2s}.interact-btn:hover{background:var(--accent-secondary)}.quest-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:.25rem;padding:.25rem .5rem;font-size:.875rem;transition:background-color .2s}.quest-btn:hover{background:var(--accent-secondary)}.interaction-widget{border-top:1px solid var(--border-color);min-height:100px;padding-top:1rem}.widget-placeholder{background:var(--bg-tertiary);height:100px;color:var(--fg-tertiary);border-radius:.25rem;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;display:flex}.widget-emoji{font-size:2rem}.widget-text{font-size:.875rem}.interaction-content{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:.5rem;flex-direction:column;gap:1rem;padding:1rem;display:flex}.interaction-title{border-bottom:2px solid var(--accent-primary);margin-bottom:.5rem;padding-bottom:.5rem}.npc-title{color:var(--fg-primary);align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:700;display:flex}.npc-title .npc-tag{color:var(--fg-tertiary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:.25rem;padding:.25rem .5rem;font-size:.875rem;font-style:italic;font-weight:400}.interaction-message{color:var(--fg-secondary);font-size:.9rem;line-height:1.6}.interaction-message p{margin:0 0 .75rem}.interaction-message p:last-child{margin-bottom:0}.quest-title{color:var(--fg-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.quest-subtitle{color:var(--fg-secondary);margin:0 0 .75rem;font-size:.875rem;font-weight:600}.quest-tasks h5{color:var(--fg-primary);margin:0 0 .5rem;font-size:1rem;font-weight:600}.quest-tasks ul{margin:0;padding-left:1.5rem}.quest-tasks li{color:var(--fg-secondary);margin-bottom:.25rem;line-height:1.4}.task-difficulty{color:var(--fg-tertiary);font-style:italic;font-weight:400}.interaction-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.accept-btn{background:var(--success-color);color:#fff;cursor:pointer;border:none;border-radius:.25rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.accept-btn:hover{background:#059669}.dismiss-btn{background:var(--accent-primary);color:#fff;cursor:pointer;border:none;border-radius:.25rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.dismiss-btn:hover{background:var(--accent-secondary)}.interaction-options{margin-top:1rem}.interaction-buttons{flex-direction:column;gap:.5rem;display:flex}.interaction-option-btn{background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;text-align:left;border-radius:.5rem;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;transition:all .2s;display:flex}.interaction-option-btn:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff;box-shadow:0 2px 4px var(--shadow-color-accent);transform:translateY(-1px)}.interaction-option-btn .option-emoji{text-align:center;min-width:1.5rem;font-size:1.25rem}.interaction-option-btn .option-text{color:var(--fg-primary);font-size:.875rem;font-weight:500}.interaction-option-btn:hover .option-text{color:#fff}.combat-map{flex-direction:column;gap:1rem;height:100%;display:flex}.combat-header{border-bottom:1px solid var(--border-color);padding-bottom:1rem}.combat-title{color:var(--fg-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.combat-subtitle{color:var(--fg-secondary);margin:0;font-size:.875rem;line-height:1.5}.combat-content{flex:1}.combat-content,.combat-placeholder{justify-content:center;align-items:center;display:flex}.combat-placeholder{background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:.5rem;flex-direction:column;gap:1rem;padding:2rem}.combat-emoji{font-size:3rem}.combat-text{color:var(--fg-secondary);text-align:center;margin:0;font-size:1rem}.combat-options{flex-direction:column;gap:1rem;display:flex}.combat-options-header{border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.combat-options-title{color:var(--fg-primary);margin:0;font-size:1rem;font-weight:600}.combat-options-content{flex:1}.combat-options-content,.combat-options-placeholder{justify-content:center;align-items:center;display:flex}.combat-options-placeholder{background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:.5rem;flex-direction:column;gap:.5rem;padding:1rem}.combat-options-emoji{font-size:2rem}.combat-options-text{color:var(--fg-secondary);text-align:center;margin:0;font-size:.875rem}.error-screen,.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100vh;display:flex}.error-emoji,.loading-emoji{font-size:3rem}.error-text,.loading-text{color:var(--fg-secondary);text-align:center;font-size:1.125rem}@media (max-width:1400px){.quest-play-container{grid-template-columns:270px 1fr 280px}}@media (max-width:1200px){.quest-play-container{grid-template:"char-widget node-name""chat main"1fr"sidebar sidebar"200px"footer footer"120px/200px 1fr;gap:.5rem}.node-name-panel{grid-area:node-name}.right-panel{grid-area:sidebar}.char-widget-panel{align-self:start;width:100%;height:fit-content}.bottom-left-panel{height:100%}}@media (max-width:768px){.main-content{flex-direction:column;gap:.5rem}.center-column,.left-column,.right-panel{width:100%}.bottom-left-panel{display:none}.right-panel{align-self:stretch}.char-widget-panel{width:100%;height:auto;min-height:120px;padding:.75rem}.node-name-panel{padding:.5rem}.abilities-grid{grid-template-columns:repeat(2,1fr)}.action-buttons{justify-content:center}}.character-widget{flex-direction:column;gap:.75rem;display:flex}.widget-header{justify-content:space-between;align-items:center;display:flex}.widget-name{color:var(--fg-primary);margin:0;font-size:1.125rem;font-weight:600}.widget-level{color:var(--accent-primary);background:var(--bg-tertiary);border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:500}.widget-health{flex-direction:column;gap:.25rem;display:flex}.widget-health .health-bar{background:var(--bg-tertiary)!important;border-radius:.25rem!important;width:100%!important;height:.5rem!important;display:block!important;overflow:hidden!important}.widget-health .health-fill{background:linear-gradient(90deg,#ef4444,#f97316)!important;height:100%!important;transition:width .3s!important;display:block!important}.widget-health .health-text{color:var(--fg-secondary)!important;text-align:center!important;font-size:.7rem!important;line-height:1.2!important}.widget-experience{flex-direction:column;gap:.25rem;display:flex}.exp-bar{background:var(--bg-tertiary);border-radius:.1875rem;width:100%;height:.375rem;overflow:hidden}.exp-fill{background:linear-gradient(90deg,#10b981,#34d399);height:100%;transition:width .3s}.exp-text{color:var(--fg-secondary);text-align:center;font-size:.75rem}.widget-status{flex-wrap:wrap;gap:.25rem;display:flex}.status-effect{background:var(--bg-tertiary);border-radius:.25rem;padding:.125rem .375rem;font-size:.75rem}.status-effect.success{color:var(--success-color)}.status-effect.info{color:var(--accent-primary)}.status-effect.warning{color:#f59e0b}.status-effect.danger{color:var(--error-color)}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}