*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family, system-ui, -apple-system, sans-serif);background-color:var(--color-background, #0a0e27);color:var(--color-text-main, #e2d8c4);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 1rem}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.flex-row{display:flex;flex-direction:row}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-1{flex:1}.flex-grow{flex-grow:1}.flex-shrink{flex-shrink:1}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:639px){.container{padding:0 .75rem}.sidebar-desktop{display:none}}@media(min-width:640px){html{font-size:16px}.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:flex-row{flex-direction:row}.md\:flex-col{flex-direction:column}}@media(min-width:1024px){html{font-size:17px}.container{padding:0 2rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.sidebar-desktop{display:flex;width:320px;flex-shrink:0}.main-content-with-sidebar{flex:1;min-width:0}}@media(min-width:1280px){.sidebar-desktop{width:380px}.container{max-width:1600px}}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-layout-with-sidebar{display:flex;flex-direction:column;min-height:100vh}@media(min-width:1024px){.app-layout-with-sidebar{flex-direction:row}}.narrative-layout{display:flex;flex-direction:column;max-width:900px;margin:0 auto;width:100%}@media(min-width:1024px){.narrative-layout{max-width:1100px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background-color:var(--color-surface, #1a1d3a);border-radius:1rem;max-width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080}@media(min-width:640px){.modal-content{max-width:540px}}@media(min-width:1024px){.modal-content{max-width:700px}.modal-content.large{max-width:900px}}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:600}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1rem}h6{font-size:.875rem}@media(min-width:1024px){h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:1.875rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background, #0a0e27)}::-webkit-scrollbar-thumb{background:var(--color-border, #3a3f5c);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary, #d4af37)}.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}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.aspect-square{aspect-ratio:1 / 1}.aspect-video{aspect-ratio:16 / 9}.aspect-portrait{aspect-ratio:3 / 4}
