.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:rgba(255,255,255,.5)}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:rgba(255,255,255,.8);margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:rgba(255,255,255,.8);text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:white;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.timeline-container{height:100%;max-height:100%;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.timeline-header{padding:8px 12px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--maroon);color:var(--cream);min-height:40px;flex-shrink:0}.timeline-header h2{color:var(--gold);margin:0;font-size:.95rem;font-weight:600}.clear-filter{padding:4px 10px;background:var(--saffron);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;min-height:44px;transition:background var(--transition-fast)}.clear-filter:hover{background:var(--saffron-dark)}.clear-filter:focus-visible{outline:var(--focus-ring-width) solid white;outline-offset:var(--focus-ring-offset)}.era-filters{display:flex;flex-wrap:wrap;gap:6px;padding:6px 10px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0;position:relative}.era-filters:after{content:"";position:absolute;right:0;top:0;bottom:0;width:30px;background:linear-gradient(to right,transparent,var(--bg-secondary));pointer-events:none;opacity:0;transition:opacity var(--transition-normal)}.era-filters.scrollable:after{opacity:1}.era-filters::-webkit-scrollbar{display:none}.era-button{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 10px;background:white;border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all var(--transition-fast);min-width:auto;flex-shrink:0;min-height:44px}.era-button:hover{border-color:var(--saffron);transform:translateY(-2px)}.era-button:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.era-button.active{background:var(--saffron);border-color:var(--saffron);color:#fff}.era-name{font-size:.85rem;font-weight:600}.era-period{font-size:.7rem;opacity:.8}.era-hint{display:flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(90deg,var(--cream) 0%,#fff8e1 100%);border-bottom:1px solid var(--border);font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.hint-icon{font-size:.9rem}.hint-text{font-style:italic}.timeline-events{flex:1;overflow-y:auto;padding:16px;min-height:0;scroll-behavior:smooth}.deselect-event-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.85rem;color:var(--text-primary);transition:all var(--transition-fast);min-height:44px}.deselect-event-btn:hover{background:var(--saffron);color:#fff;border-color:var(--saffron)}.deselect-event-btn:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.timeline-event{display:flex;gap:12px;padding:12px;margin-bottom:8px;background:white;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.timeline-event:hover{border-color:var(--saffron);box-shadow:0 2px 8px #0000001a}.timeline-event:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.timeline-event.selected{border-color:var(--maroon);background:var(--cream)}.event-marker{display:flex;flex-direction:column;align-items:center}.event-dot{width:12px;height:12px;border-radius:50%;background:var(--saffron);border:2px solid white;box-shadow:0 0 0 2px var(--saffron)}.timeline-event.selected .event-dot{background:var(--maroon);box-shadow:0 0 0 2px var(--maroon)}.event-line{flex:1;width:2px;background:var(--border);margin-top:4px}.event-content{flex:1}.event-header{margin-bottom:4px}.event-title{color:var(--maroon);margin:0 0 2px;font-size:1rem}.event-sanskrit{font-size:.8rem;color:var(--text-secondary);font-style:italic}.event-meta{display:flex;gap:12px;margin-bottom:8px;font-size:.8rem;color:var(--text-secondary)}.event-description{font-size:.9rem;color:var(--text-primary);line-height:var(--leading-normal)}.event-details{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.detail-section{margin-bottom:12px}.detail-section h5{color:var(--maroon);margin:0 0 4px;font-size:.9rem}.detail-section p{font-size:.85rem;color:var(--text-secondary);margin:0}.characters-list{display:flex;flex-wrap:wrap;gap:6px}.character-tag{padding:2px 8px;background:var(--bg-secondary);border-radius:12px;font-size:.75rem;color:var(--text-primary)}.read-story-btn{width:100%;padding:12px 16px;margin-top:12px;background:linear-gradient(135deg,var(--saffron) 0%,var(--maroon) 100%);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast);min-height:44px;display:flex;align-items:center;justify-content:center;gap:8px}.read-story-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.read-story-btn:focus-visible{outline:var(--focus-ring-width) solid var(--gold);outline-offset:var(--focus-ring-offset)}.read-story-btn:active{transform:translateY(0)}@media (max-width: 768px){.timeline-header{padding:10px 12px;min-height:50px}.timeline-header h2{font-size:1rem}.clear-filter{padding:5px 10px;font-size:.8rem}.era-filters{padding:8px;gap:6px;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.era-filters::-webkit-scrollbar{display:none}.era-button{min-width:auto;padding:8px 12px;min-height:40px;flex-shrink:0}.era-name{font-size:.75rem;white-space:nowrap}.era-period{display:none}.era-hint{padding:5px 10px;font-size:.75rem}.timeline-events{padding:10px}.timeline-event{padding:10px;gap:10px}.event-title{font-size:.9rem}.event-sanskrit{font-size:.7rem}.event-meta{flex-wrap:wrap;gap:8px;font-size:.7rem}.event-description{font-size:.8rem;line-height:1.4}.character-tag{font-size:.7rem;padding:2px 6px}}@media (max-width: 480px){.timeline-header h2{font-size:1rem}.era-button{min-width:60px;padding:4px 6px}.era-name,.era-hint{font-size:.7rem}.timeline-event{padding:8px}.event-title{font-size:.85rem}.event-description{font-size:.75rem}}@media (hover: none) and (pointer: coarse){.timeline-event,.era-button{min-height:44px}}@media (prefers-reduced-motion: reduce){.era-button:hover,.read-story-btn:hover{transform:none}}.location-panel{position:absolute;top:0;right:0;width:400px;height:100%;background:var(--bg-primary);border-left:3px solid var(--border);box-shadow:-4px 0 20px #0000004d;z-index:1000;overflow-y:auto}.panel-header{position:sticky;top:0;background:var(--bg-primary);padding:20px;border-bottom:3px solid;z-index:10}.close-btn{position:absolute;top:10px;right:10px;width:44px;height:44px;background:var(--bg-secondary);border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.close-btn:hover{background:var(--saffron);color:#fff}.close-btn:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.panel-header h2{margin:0 0 8px;color:var(--maroon);font-size:1.8rem;padding-right:40px}.sanskrit-name{display:block;font-size:1.1rem;color:var(--text-secondary);margin-bottom:12px;font-style:italic}.location-type{display:inline-block;padding:4px 12px;border-radius:20px;color:#fff;font-size:.85rem;font-weight:600}.panel-content{padding:20px}.info-section{margin-bottom:24px}.info-section h3{color:var(--maroon);border-bottom:2px solid var(--border);padding-bottom:8px;margin-bottom:12px;font-size:1.2rem}.info-section p{line-height:var(--leading-normal);color:var(--text-on-cream);margin-bottom:12px}.significance{background:var(--bg-secondary);padding:12px;border-radius:8px;border-left:4px solid var(--saffron)}.rulers-list{list-style:none;padding:0}.rulers-list li{padding:8px 12px;background:var(--bg-secondary);margin-bottom:6px;border-radius:4px;border-left:3px solid var(--gold)}.details-grid{display:grid;gap:12px}.detail-item{background:var(--bg-secondary);padding:12px;border-radius:8px}.detail-key{display:block;font-weight:600;color:var(--maroon);text-transform:capitalize;margin-bottom:4px}.detail-value{color:var(--text-secondary);font-size:.95rem}.events-list{display:flex;flex-direction:column;gap:12px}.event-card{background:white;padding:16px;border-radius:8px;border:2px solid var(--border);cursor:pointer;transition:all var(--transition-fast)}.event-card:hover{border-color:var(--saffron);box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.event-card:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.event-card h4{margin:0 0 8px;color:var(--maroon);font-size:1rem}.event-year{display:inline-block;background:var(--saffron);color:#fff;padding:2px 8px;border-radius:4px;font-size:.75rem;margin-bottom:8px}.event-card p{margin:0;font-size:.9rem;color:var(--text-secondary)}@media (max-width: 1024px){.location-panel{width:350px}.panel-header h2{font-size:1.5rem}}@media (max-width: 768px){.location-panel{width:100%;max-width:100%;position:fixed;top:auto;bottom:0;left:0;right:0;height:60vh;max-height:60vh;border-left:none;border-top:3px solid var(--border);border-radius:16px 16px 0 0;padding-bottom:env(safe-area-inset-bottom,20px)}.panel-header{padding:16px;position:sticky;top:0;padding-top:max(16px,env(safe-area-inset-top,16px))}.panel-header h2{font-size:1.3rem}.sanskrit-name{font-size:.95rem}.panel-content{padding:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom,20px))}.close-btn{top:max(12px,env(safe-area-inset-top,12px));right:12px;width:44px;height:44px;background:var(--maroon);color:#fff;min-width:44px;min-height:44px}.info-section h3{font-size:1.1rem}.events-list{gap:10px}.event-card{padding:12px}.event-card h4{font-size:.95rem}.event-card p{font-size:.85rem}.details-grid{gap:10px}.detail-item{padding:10px}.rulers-list li{padding:6px 10px;font-size:.9rem}}@media (max-width: 480px){.location-panel{height:70vh;max-height:70vh;padding-bottom:env(safe-area-inset-bottom,20px)}.panel-header h2{font-size:1.2rem;padding-right:50px}.sanskrit-name{font-size:.9rem}.panel-content{padding:12px;padding-bottom:calc(60px + env(safe-area-inset-bottom,20px))}.info-section h3{font-size:1rem}.info-section p{font-size:.9rem}.detail-key,.detail-value{font-size:.85rem}}@media (hover: none) and (pointer: coarse){.event-card{min-height:44px}.close-btn{min-width:44px;min-height:44px}}@media (prefers-reduced-motion: reduce){.event-card:hover{transform:none}}.legend-toggle{display:flex;align-items:center;justify-content:center;gap:6px;position:absolute;bottom:20px;right:20px;width:50px;height:50px;background:var(--maroon);color:#fff;border:none;border-radius:50%;box-shadow:0 3px 10px #0000004d;cursor:pointer;z-index:499;font-size:1.2rem;transition:all var(--transition-fast)}.legend-toggle:hover{background:var(--maroon-light)}.legend-toggle:focus-visible{outline:var(--focus-ring-width) solid var(--gold);outline-offset:var(--focus-ring-offset)}.legend-toggle-icon{font-size:1.3rem}.legend-toggle-text{position:absolute;top:-4px;right:-4px;background:var(--saffron);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.legend-panel{position:absolute;bottom:80px;right:20px;background:rgba(255,255,255,.98);padding:16px;border-radius:12px;box-shadow:0 4px 20px #0003;z-index:500;max-width:220px;max-height:60vh;overflow-y:auto}.legend-header{display:none}.legend-panel h3{margin:0 0 12px;color:var(--maroon);font-size:1rem;border-bottom:2px solid var(--border);padding-bottom:8px}.legend-content{display:flex;flex-direction:column;gap:4px}.legend-divider{height:1px;background:var(--border);margin:8px 0}.legend-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:2px solid transparent;border-radius:6px;cursor:pointer;width:100%;text-align:left;transition:all var(--transition-fast);min-height:44px}.legend-item:hover{background:var(--bg-secondary)}.legend-item:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.legend-item.inactive{opacity:.4}.legend-item.active{border-color:var(--border)}.legend-item.all{font-weight:600;background:var(--bg-secondary)}.legend-marker{width:16px;height:16px;border-radius:50%;border:2px solid white;box-shadow:0 1px 3px #0000004d;flex-shrink:0}.legend-label{font-size:.9rem;color:var(--text-primary)}@media (max-width: 768px){.legend-toggle{display:flex;align-items:center;justify-content:center;gap:6px;position:absolute;top:70px;right:10px;width:44px;height:44px;background:var(--maroon);color:#fff;border:none;border-radius:50%;box-shadow:0 3px 10px #0000004d;cursor:pointer;z-index:499;font-size:1.2rem;min-width:44px;min-height:44px}.legend-toggle-icon{font-size:1.3rem}.legend-toggle-text{position:absolute;top:-4px;right:-4px;background:var(--saffron);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.legend-panel{position:fixed;bottom:0;left:0;right:0;top:auto;max-width:100%;max-height:50vh;border-radius:20px 20px 0 0;padding:0;z-index:1001}.legend-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:2px solid var(--border);background:var(--bg-primary);border-radius:20px 20px 0 0;position:sticky;top:0;z-index:10}.legend-header h3{margin:0;border:none;padding:0;font-size:1.1rem}.legend-close{width:36px;height:36px;background:var(--bg-secondary);border:none;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;min-height:44px;min-width:44px}.legend-close:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.legend-content{padding:16px 20px;display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.legend-divider{grid-column:1 / -1;margin:4px 0}.legend-item{padding:10px 8px;min-height:44px}.legend-item.all{grid-column:1 / -1}.legend-marker{width:14px;height:14px}.legend-label{font-size:.85rem}}@media (max-width: 480px){.legend-toggle{width:40px;height:40px;top:65px;right:8px;min-width:40px;min-height:40px}.legend-toggle-icon{font-size:1.1rem}.legend-header{padding:12px 16px}.legend-header h3{font-size:1rem}.legend-content{padding:12px 16px;gap:6px}.legend-item{padding:8px 6px}.legend-marker{width:12px;height:12px}.legend-label{font-size:.8rem}}@media (hover: none) and (pointer: coarse){.legend-toggle{min-height:44px;min-width:44px}.legend-item{min-height:44px}.legend-close{min-height:44px;min-width:44px}}@media (prefers-reduced-motion: reduce){.legend-toggle,.legend-item{transition:none}}.story-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);z-index:1000;display:flex;justify-content:flex-end}.story-panel{width:100vw;height:100vh;background:linear-gradient(180deg,#1a1a2e 0%,#16213e 50%,#0f0f23 100%);overflow-y:auto;overflow-x:hidden;position:relative;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}@media (min-width: 768px){.story-panel{width:60vw;max-width:700px;border-left:1px solid rgba(255,215,0,.2);box-shadow:-10px 0 40px #00000080}}@media (min-width: 1024px){.story-panel{width:50vw;max-width:800px}}@media (min-width: 1024px){.story-panel--longform{max-width:860px}}.story-content-wrapper{flex:1;padding-bottom:16px}.story-panel--longform .story-content-wrapper{padding-bottom:48px}.story-header{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(180deg,rgba(26,26,46,.98) 0%,rgba(26,26,46,.9) 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,215,0,.15);min-height:56px}.story-back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:#e0e0e0;font-size:14px;cursor:pointer;padding:8px 12px;margin:-8px -12px;border-radius:8px;transition:background .2s;min-width:44px;min-height:44px}.story-back-btn:hover{background:rgba(255,255,255,.1)}.story-back-btn:active{background:rgba(255,255,255,.15)}.story-header-actions{display:flex;align-items:center;gap:8px}.story-toc-btn{background:none;border:1px solid rgba(255,215,0,.3);color:gold;font-size:16px;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.story-toc-btn:hover,.story-toc-btn.active{background:rgba(255,215,0,.15);border-color:#ffd70080}.story-share-btn{background:none;border:1px solid rgba(255,215,0,.3);color:gold;font-size:18px;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s;min-width:44px;min-height:44px}.story-share-btn:hover{background:rgba(255,215,0,.1);border-color:#ffd70080}.story-toc{position:sticky;top:56px;z-index:9;background:rgba(15,15,35,.98);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,215,0,.15);max-height:60vh;overflow-y:auto;animation:tocSlideDown .25s ease-out}@keyframes tocSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.story-toc-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px 8px;border-bottom:1px solid rgba(255,255,255,.06)}.story-toc-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:gold}.story-toc-count{font-size:11px;color:#fff6}.story-toc-list{list-style:none;margin:0;padding:8px 12px 12px}.story-toc-list li{margin:0}.story-toc-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 8px;background:none;border:none;border-radius:8px;cursor:pointer;text-align:left;transition:all .2s;color:#ffffffa6;font-size:14px}.story-toc-item:hover{background:rgba(255,215,0,.08);color:#ffffffe6}.story-toc-item.active{background:rgba(255,215,0,.12);color:gold}.story-toc-item.read{color:#ffd70080}.story-toc-num{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.story-toc-item.active .story-toc-num{background:linear-gradient(135deg,#ffd700,#ff8c00);color:#1a1a2e}.story-toc-item.read .story-toc-num{background:rgba(255,215,0,.2);color:gold}.story-toc-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-toc-time{font-size:11px;color:#ffffff4d;flex-shrink:0}.story-hero{position:relative;height:55vh;min-height:300px;max-height:500px;overflow:hidden}.story-hero-image-container{width:100%;height:100%;position:relative}.story-hero-image{width:100%;height:100%;object-fit:cover;filter:brightness(.7);transition:opacity .5s ease-in-out}.story-hero-image.loading{opacity:0;position:absolute;top:0;left:0}.story-hero-image.loaded{opacity:1}.story-hero-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#2d1f3d 0%,#1a1a2e 50%,#0d1b2a 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:#ffd70099}.story-hero-placeholder-icon{font-size:48px;opacity:.5}.story-hero-gradient{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,#1a1a2e 0%,transparent 100%);pointer-events:none}.story-title-section{padding:24px 20px 16px;text-align:center;margin-top:-60px;position:relative;z-index:5}.story-sanskrit{font-size:24px;color:gold;margin-bottom:8px;text-shadow:0 2px 10px rgba(255,215,0,.3)}.story-title{font-size:28px;font-weight:700;color:#fff;margin:0 0 12px;text-transform:uppercase;letter-spacing:2px}.story-meta{display:flex;justify-content:center;gap:20px;font-size:13px;color:#fff9;flex-wrap:wrap}.story-meta-item{display:flex;align-items:center;gap:6px}.story-meta-longform{background:rgba(255,215,0,.1);border:1px solid rgba(255,215,0,.25);padding:2px 10px;border-radius:12px;color:gold;font-weight:600;font-size:11px;letter-spacing:.5px}.story-divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,#ffd700,transparent);margin:20px auto 0}.story-scenes{padding:0 20px 120px}.story-scene{margin-bottom:40px;opacity:0;transform:translateY(20px);animation:fadeInUp .6s ease forwards}.story-scene:nth-child(1){animation-delay:.1s}.story-scene:nth-child(2){animation-delay:.2s}.story-scene:nth-child(3){animation-delay:.3s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.scene-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.scene-number{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#ffd700 0%,#ff8c00 100%);color:#1a1a2e;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.scene-title{font-size:18px;font-weight:600;color:gold;margin:0}.scene-location{display:flex;align-items:center;gap:6px;font-size:12px;color:#ffffff80;margin-bottom:16px;padding-left:44px}.scene-narrative{font-size:16px;line-height:1.8;color:#ffffffe6;white-space:pre-line}.scene-narrative p{margin-bottom:16px}.scene-image{margin:24px 0;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0006}.scene-image img{width:100%;height:auto;display:block}.story-scenes--continuous{padding:0 20px 60px}.story-scene-block{margin-bottom:16px}.scene-divider{display:flex;align-items:center;justify-content:center;padding:32px 0 28px}.scene-divider-ornament{color:#ffd70066;font-size:16px;position:relative}.scene-divider-ornament:before,.scene-divider-ornament:after{content:"";position:absolute;top:50%;width:60px;height:1px;background:linear-gradient(90deg,transparent,rgba(255,215,0,.2))}.scene-divider-ornament:before{right:calc(100% + 12px);background:linear-gradient(90deg,transparent,rgba(255,215,0,.2))}.scene-divider-ornament:after{left:calc(100% + 12px);background:linear-gradient(90deg,rgba(255,215,0,.2),transparent)}.scene-header--longform{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}.scene-header--longform .scene-number{margin-top:2px}.scene-header-text{flex:1;min-width:0}.scene-header--longform .scene-title{font-size:20px;margin-bottom:6px;line-height:1.3}.scene-sub-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.scene-location-tag,.scene-readtime-tag{font-size:12px;color:#ffffff73;display:flex;align-items:center;gap:4px}.scene-readtime-tag{color:#ffd70080}.scene-image-block{margin:16px 0 20px;border-radius:12px;overflow:hidden;box-shadow:0 6px 24px #00000059;aspect-ratio:16/9}.scene-image-block .skeleton-loader{border-radius:12px}.scene-narrative--longform{font-size:16.5px;line-height:1.85;color:#ffffffe0;white-space:pre-line;letter-spacing:.01em}@media (min-width: 768px){.scene-narrative--longform{font-size:17px;line-height:1.9}}.pull-quote{position:relative;margin:32px 0;padding:24px 24px 20px 28px;border-left:3px solid #ffd700;background:linear-gradient(135deg,rgba(255,215,0,.06) 0%,rgba(255,140,0,.03) 100%);border-radius:0 12px 12px 0}.pull-quote-mark{position:absolute;top:8px;left:12px;font-size:48px;line-height:1;color:#ffd70026;font-family:Georgia,Times New Roman,serif;pointer-events:none}.pull-quote-text{font-size:17px;line-height:1.7;color:#ffffffeb;font-style:italic;margin:0 0 12px;padding-left:4px}.pull-quote-attribution{display:block;font-size:13px;color:gold;font-style:normal;letter-spacing:.5px;padding-left:4px}@media (min-width: 768px){.pull-quote{margin:40px 16px;padding:28px 32px 24px 36px}.pull-quote-text{font-size:18px}}.sanskrit-verse-block{margin:24px 0;padding:20px 24px;background:linear-gradient(135deg,rgba(139,69,19,.15) 0%,rgba(255,215,0,.05) 100%);border:1px solid rgba(255,215,0,.15);border-radius:12px;text-align:center}.sanskrit-devanagari{font-size:22px;color:gold;margin-bottom:8px;line-height:1.6;text-shadow:0 1px 8px rgba(255,215,0,.2)}.sanskrit-transliteration{font-size:14px;color:#ffffff8c;font-style:italic;margin-bottom:10px;letter-spacing:.3px}.sanskrit-translation{font-size:14px;color:#ffffffbf;line-height:1.6;border-top:1px solid rgba(255,255,255,.08);padding-top:10px}@media (min-width: 768px){.sanskrit-verse-block{margin:28px 16px}.sanskrit-devanagari{font-size:26px}}.trivia-card{margin:24px 0;border-radius:12px;border:1px solid rgba(255,215,0,.15);background:rgba(255,215,0,.04);overflow:hidden;transition:border-color .3s}.trivia-card.expanded{border-color:#ffd7004d}.trivia-card-header{display:flex;align-items:center;gap:10px;width:100%;padding:14px 16px;background:none;border:none;cursor:pointer;transition:background .2s;color:inherit;font-size:inherit}.trivia-card-header:hover{background:rgba(255,215,0,.06)}.trivia-icon{font-size:18px;flex-shrink:0}.trivia-label{font-size:14px;font-weight:600;color:gold;flex:1;text-align:left;letter-spacing:.3px}.trivia-chevron{font-size:10px;color:#ffd70080;transition:transform .3s;flex-shrink:0}.trivia-chevron.open{transform:rotate(180deg)}.trivia-card-body{padding:0 16px 16px;animation:triviaExpand .3s ease-out}@keyframes triviaExpand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.trivia-card-body p{margin:0;font-size:14px;line-height:1.7;color:#ffffffb8;font-style:italic}.dharma-lesson{margin:40px 0;padding:24px;background:linear-gradient(135deg,rgba(255,215,0,.1) 0%,rgba(255,140,0,.05) 100%);border:1px solid rgba(255,215,0,.2);border-radius:16px;position:relative}.dharma-lesson:before{content:"🕉️";position:absolute;top:-15px;left:50%;transform:translate(-50%);font-size:28px;background:#1a1a2e;padding:0 12px}.dharma-lesson-title{text-align:center;font-size:14px;font-weight:600;color:gold;text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}.dharma-lesson-text{font-size:15px;line-height:1.8;color:#ffffffd9;font-style:italic;text-align:center}.story-end-section{text-align:center;padding:40px 20px 60px}.story-end-ornament{font-size:36px;color:#ffd70066;margin-bottom:16px}.story-end-text{font-size:16px;color:#ffffff80;font-style:italic;margin-bottom:24px}.story-end-close-btn{padding:12px 32px;background:linear-gradient(135deg,#ffd700 0%,#ff8c00 100%);border:none;border-radius:24px;color:#1a1a2e;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.5px}.story-end-close-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffd7004d}.story-end-close-btn:active{transform:translateY(0)}.longform-scene-indicator{position:sticky;bottom:0;z-index:100;display:flex;align-items:center;gap:10px;padding:10px 20px;background:linear-gradient(180deg,rgba(15,15,35,.95) 0%,rgba(10,10,25,1) 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,215,0,.12);min-height:44px}.longform-scene-num{font-size:12px;font-weight:700;color:gold;background:rgba(255,215,0,.12);padding:3px 10px;border-radius:10px;letter-spacing:.5px;flex-shrink:0}.longform-scene-name{font-size:13px;color:#fff9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.story-nav{position:sticky;bottom:0;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:linear-gradient(180deg,rgba(26,26,46,.98) 0%,rgba(15,15,35,1) 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,215,0,.15);z-index:100;min-height:56px;margin-top:auto}@media (min-width: 768px){.story-nav{padding:14px 24px}}@media (min-width: 1024px){.story-nav{padding:16px 28px}}.story-nav-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e0e0e0;font-size:14px;cursor:pointer;transition:all .2s;min-width:44px;min-height:44px}.story-nav-btn:hover:not(:disabled){background:rgba(255,215,0,.1);border-color:#ffd7004d;color:gold}.story-nav-btn:disabled{opacity:.3;cursor:not-allowed}.story-nav-btn.primary{background:linear-gradient(135deg,#ffd700 0%,#ff8c00 100%);border:none;color:#1a1a2e;font-weight:600}.story-nav-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#ffdf00 0%,#ffa500 100%);color:#1a1a2e}.story-progress{display:flex;gap:6px}.story-progress-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);transition:all .3s;border:none;padding:0;cursor:pointer}.story-progress-dot.active{background:#ffd700;transform:scale(1.2)}.story-progress-dot.completed{background:rgba(255,215,0,.5)}.scene-characters{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.story-scenes:not(.story-scenes--continuous) .scene-characters{padding-left:44px}.scene-character-tag{padding:4px 12px;background:rgba(255,215,0,.15);border:1px solid rgba(255,215,0,.3);border-radius:16px;font-size:13px;color:#ffffffe6}.character-tag{padding:4px 10px;background:rgba(255,215,0,.1);border:1px solid rgba(255,215,0,.2);border-radius:16px;font-size:11px;color:#ffd700cc}.image-placeholder{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#2d1f3d 0%,#1a1a2e 50%,#0d1b2a 100%);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;text-align:center}.image-placeholder-icon{font-size:36px;opacity:.6}.image-placeholder-text{font-size:14px;color:#fff9}.image-placeholder-timer{font-size:12px;color:gold;display:flex;align-items:center;gap:6px}.image-placeholder-prompt{font-size:11px;color:#fff6;font-style:italic;max-width:300px;line-height:1.5}.swipe-indicator{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:rgba(0,0,0,.7);padding:8px 16px;border-radius:20px;font-size:12px;color:#ffffffb3;display:flex;align-items:center;gap:8px;opacity:0;animation:fadeInOut 3s ease forwards;pointer-events:none}@keyframes fadeInOut{0%{opacity:0}10%{opacity:1}70%{opacity:1}to{opacity:0}}@media (min-width: 768px){.swipe-indicator{display:none}}.story-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:20px}.story-loading-spinner{width:48px;height:48px;border:3px solid rgba(255,215,0,.2);border-top-color:gold;border-radius:50%;animation:spin 1s linear infinite}.story-loading-text{color:#fff9;font-size:14px}.story-progress-bar-container{position:absolute;top:0;left:0;right:0;height:3px;background:rgba(255,255,255,.1);z-index:20}.story-progress-bar{height:100%;background:linear-gradient(90deg,var(--saffron, #ff6b35),var(--gold, #ffd700));transition:width .3s ease}.skeleton-loader{width:100%;height:100%;background:linear-gradient(90deg,rgba(255,255,255,.05) 25%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-icon{font-size:48px;opacity:.3;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.5}}.skeleton-text{font-size:14px;color:#fff6}.view-on-map-btn{background:none;border:none;color:var(--gold, #ffd700);cursor:pointer;font-size:11px;margin-left:4px;padding:4px 8px;border-radius:4px;transition:all .2s;min-height:32px}.view-on-map-btn:hover{background:rgba(255,215,0,.1)}.view-on-map-btn:focus-visible{outline:2px solid var(--gold, #ffd700);outline-offset:2px}.story-panel:focus-visible{outline:none}.story-back-btn:focus-visible,.story-share-btn:focus-visible,.story-toc-btn:focus-visible,.story-nav-btn:focus-visible,.view-on-map-btn:focus-visible,.story-toc-item:focus-visible,.trivia-card-header:focus-visible{outline:2px solid var(--gold, #ffd700);outline-offset:2px}.story-progress-dot:focus-visible{outline:2px solid var(--gold, #ffd700);outline-offset:2px}@media (prefers-reduced-motion: reduce){.story-scene{animation:none;opacity:1;transform:none}.story-hero-image{transition:none}.skeleton-loader,.skeleton-icon{animation:none}.swipe-indicator{animation:none;opacity:0}.story-progress-bar{transition:none}.story-toc,.trivia-card-body{animation:none}.trivia-chevron{transition:none}}.map-mini-view{position:fixed;bottom:80px;right:16px;width:100px;height:100px;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #0006;border:2px solid rgba(255,215,0,.4);z-index:90;background:#1a1a2e;transition:all .3s ease}.map-mini-view:hover{transform:scale(1.05);border-color:#ffd700b3}.mini-map-container{width:100%;height:100%}.mini-map-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.85),transparent);padding:20px 6px 6px;display:flex;align-items:center;gap:4px;pointer-events:none}.mini-map-icon{font-size:10px}.mini-map-name{font-size:9px;color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-marker{background:transparent}.mini-marker-dot{width:12px;height:12px;border-radius:50%;border:2px solid white;box-shadow:0 0 8px #ffd70099;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}@media (min-width: 768px){.map-mini-view{display:none}}@media (min-width: 768px) and (max-width: 1023px){.map-mini-view{display:block;bottom:80px;right:calc(60vw + 16px)}}.journey-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px}.journey-selector-modal{width:100%;max-width:600px;max-height:90vh;background:linear-gradient(180deg,#1a1a2e 0%,#16213e 50%,#0f0f23 100%);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;border:1px solid rgba(255,215,0,.2)}.journey-selector-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,215,0,.15)}.journey-selector-title h2{margin:0;font-size:22px;color:#fff;font-weight:600}.journey-selector-sanskrit{font-size:14px;color:gold;opacity:.8}.journey-close-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.1);border:none;color:#fff;font-size:18px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.journey-close-btn:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}.journey-tabs{display:flex;gap:8px;padding:16px 24px;background:rgba(0,0,0,.2)}.journey-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#fff9;font-size:14px;cursor:pointer;transition:all .2s;min-height:44px}.journey-tab:hover{background:rgba(255,255,255,.1);color:#fff}.journey-tab.active{background:linear-gradient(135deg,rgba(255,215,0,.2) 0%,rgba(255,140,0,.1) 100%);border-color:#ffd70066;color:gold}.journey-list{flex:1;overflow-y:auto;padding:16px 24px 24px;display:flex;flex-direction:column;gap:12px}.journey-card{display:flex;gap:16px;padding:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;cursor:pointer;transition:all .2s}.journey-card:hover{background:rgba(255,215,0,.05);border-color:#ffd7004d;transform:translate(4px)}.journey-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:28px;background:rgba(255,215,0,.1);border-radius:12px;flex-shrink:0}.journey-card-content{flex:1;min-width:0}.journey-card-title{margin:0 0 2px;font-size:16px;font-weight:600;color:#fff}.journey-card-sanskrit{font-size:12px;color:gold;margin-bottom:8px}.journey-card-description{font-size:13px;color:#fff9;line-height:1.5;margin:0 0 10px}.journey-card-meta{display:flex;gap:16px;margin-bottom:10px}.journey-card-time,.journey-card-stories{display:flex;align-items:center;gap:4px;font-size:12px;color:#ffffff80}.journey-card-highlights{display:flex;flex-wrap:wrap;gap:6px}.highlight-tag{padding:3px 8px;background:rgba(255,215,0,.1);border-radius:12px;font-size:10px;color:#ffd700cc}.journey-card-arrow{display:flex;align-items:center;font-size:20px;color:#ffffff4d;transition:all .2s}.journey-card:hover .journey-card-arrow{color:gold;transform:translate(4px)}@media (max-width: 600px){.journey-selector-overlay{padding:0;align-items:flex-end}.journey-selector-modal{max-width:100%;max-height:85vh;border-radius:20px 20px 0 0}.journey-selector-header{padding:16px 20px}.journey-selector-title h2{font-size:18px}.journey-tabs{padding:12px 16px}.journey-list{padding:12px 16px 20px}.journey-card{padding:14px}.journey-card-icon{width:40px;height:40px;font-size:22px}.journey-card-title{font-size:14px}.journey-card-description{font-size:12px}}.journey-progress{position:fixed;top:0;left:0;right:0;background:linear-gradient(180deg,rgba(26,26,46,.98) 0%,rgba(26,26,46,.95) 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1050;padding:12px 16px;border-bottom:1px solid rgba(255,215,0,.2);box-shadow:0 4px 20px #0000004d}.journey-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.journey-progress-info{display:flex;align-items:center;gap:12px}.journey-progress-icon{font-size:24px}.journey-progress-text{display:flex;flex-direction:column}.journey-progress-title{font-size:14px;font-weight:600;color:#fff}.journey-progress-count{font-size:11px;color:#fff9}.journey-exit-btn{padding:8px 14px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:20px;color:#fffc;font-size:12px;cursor:pointer;transition:all .2s;min-height:36px}.journey-exit-btn:hover{background:rgba(255,100,100,.2);border-color:#ff646466;color:#ff8080}.journey-progress-bar{position:relative;height:6px;background:rgba(255,255,255,.1);border-radius:3px;overflow:visible}.journey-progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#ffd700 0%,#ff8c00 100%);border-radius:3px;transition:width .5s ease}.journey-story-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:#1a1a2e;border:2px solid rgba(255,255,255,.3);cursor:pointer;transition:all .2s;padding:0}.journey-story-dot:hover{transform:translate(-50%,-50%) scale(1.2);border-color:#ffd70099}.journey-story-dot.completed{background:#ffd700;border-color:gold}.journey-story-dot.active{background:#fff;border-color:gold;transform:translate(-50%,-50%) scale(1.3);box-shadow:0 0 12px #ffd70099}@media (min-width: 768px){.journey-progress{padding:12px 24px}.journey-progress-title{font-size:15px}}@media (min-width: 768px){.journey-progress.with-story-panel{right:60vw;max-width:40vw}}@media (min-width: 1024px){.journey-progress.with-story-panel{right:50vw;max-width:50vw}}.character-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);z-index:1000;display:flex;justify-content:center;align-items:flex-end}.character-panel{width:100%;max-height:90vh;background:var(--bg-primary);border-radius:20px 20px 0 0;overflow:hidden;display:flex;flex-direction:column}@media (min-width: 768px){.character-panel-overlay{align-items:center}.character-panel{width:90%;max-width:800px;max-height:85vh;border-radius:20px}}.character-panel-header{padding:20px;background:linear-gradient(135deg,var(--maroon) 0%,var(--maroon-light) 100%);color:#fff;display:flex;align-items:center;gap:12px;flex-shrink:0}.character-panel-header h2{color:var(--gold);margin:0;font-size:1.5rem}.character-panel-sanskrit{font-family:Noto Sans Devanagari,sans-serif;color:var(--cream);opacity:.8;margin-right:auto}.character-close-btn{width:44px;height:44px;background:rgba(255,255,255,.1);border:2px solid var(--gold);border-radius:50%;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.character-close-btn:hover{background:var(--gold);color:var(--maroon)}.character-close-btn:focus-visible{outline:var(--focus-ring-width) solid white;outline-offset:var(--focus-ring-offset)}.character-search-container{position:relative;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.character-search{width:100%;padding:12px 44px 12px 16px;background:white;border:2px solid var(--border);border-radius:8px;font-size:1rem;color:var(--text-primary);transition:border-color var(--transition-fast);min-height:44px}.character-search::placeholder{color:var(--text-secondary)}.character-search:focus{border-color:var(--saffron);outline:none}.character-search:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.search-clear-btn{position:absolute;right:28px;top:50%;transform:translateY(-50%);width:32px;height:32px;background:var(--bg-secondary);border:none;border-radius:50%;cursor:pointer;font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.search-clear-btn:hover{background:var(--maroon);color:#fff}.search-clear-btn:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.faction-filters{display:flex;gap:8px;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.faction-filters::-webkit-scrollbar{display:none}.faction-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:white;border:2px solid var(--border);border-radius:20px;cursor:pointer;font-size:.85rem;color:var(--text-primary);transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0;min-height:44px}.faction-btn:hover{border-color:var(--saffron)}.faction-btn:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.faction-btn.active{background:var(--saffron);border-color:var(--saffron);color:#fff}.character-grid{flex:1;overflow-y:auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;align-content:start}@media (min-width: 768px){.character-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}}.character-card{background:white;border-radius:12px;padding:16px;text-align:center;cursor:pointer;transition:all var(--transition-fast);border:2px solid transparent;border-left-width:4px}.character-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.character-card:focus-visible,.character-card.focused{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.character-card-icon{width:48px;height:48px;border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem}.character-card-name{font-weight:600;color:var(--maroon);margin-bottom:4px;font-size:.95rem}.character-card-sanskrit{font-size:.8rem;color:var(--text-secondary);font-style:italic;margin-bottom:4px}.character-card-title{font-size:.75rem;color:var(--text-secondary)}.no-results{grid-column:1 / -1;text-align:center;padding:40px 20px;color:var(--text-secondary)}.no-results p{margin-bottom:16px}.no-results button{padding:10px 20px;background:var(--saffron);color:#fff;border:none;border-radius:8px;cursor:pointer;min-height:44px}.no-results button:focus-visible{outline:var(--focus-ring-width) solid var(--maroon);outline-offset:var(--focus-ring-offset)}.character-detail{flex:1;overflow-y:auto;background:var(--bg-primary)}.character-detail-header{position:sticky;top:0;background:var(--maroon);padding:12px 16px;display:flex;justify-content:space-between;align-items:center;z-index:10}.character-back-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(255,255,255,.1);border:2px solid var(--gold);border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;transition:all var(--transition-fast);min-height:44px}.character-back-btn:hover{background:var(--gold);color:var(--maroon)}.character-back-btn:focus-visible{outline:var(--focus-ring-width) solid white;outline-offset:var(--focus-ring-offset)}.character-hero{padding:40px 20px;text-align:center}.character-hero-icon{font-size:3rem;margin-bottom:16px}.character-hero-name{color:var(--maroon);margin:0 0 8px;font-size:2rem}.character-hero-sanskrit{font-family:Noto Sans Devanagari,sans-serif;color:var(--text-secondary);font-size:1.1rem;margin-bottom:8px}.character-hero-title{color:var(--text-secondary);font-size:.9rem}.character-traits{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px 20px;justify-content:center}.trait-tag{padding:6px 14px;background:white;border:2px solid;border-radius:20px;font-size:.85rem;color:var(--text-primary)}.character-section{padding:20px}.character-description{font-size:1rem;line-height:var(--leading-relaxed);color:var(--text-on-cream);margin:0}.character-quote{margin:20px;padding:20px;background:linear-gradient(135deg,var(--maroon) 0%,var(--maroon-light) 100%);border-radius:12px;color:var(--cream);font-style:italic;font-size:1.1rem;line-height:var(--leading-relaxed);text-align:center}.quote-mark{font-size:1.5rem;color:var(--gold)}.character-section h3{color:var(--maroon);margin:0 0 16px;font-size:1.1rem;border-bottom:2px solid var(--border);padding-bottom:8px}.story-appearances{display:flex;flex-direction:column;gap:10px}.story-appearance-card{background:white;padding:14px 16px;border-radius:8px;border:2px solid var(--border);cursor:pointer;text-align:left;transition:all var(--transition-fast);min-height:44px}.story-appearance-card:hover{border-color:var(--saffron);transform:translate(4px)}.story-appearance-card:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}.story-appearance-title{font-weight:600;color:var(--maroon);margin-bottom:4px}.story-appearance-role{font-size:.85rem;color:var(--text-secondary)}.journey-highlights{list-style:none;padding:0;margin:0;counter-reset:highlight}.journey-highlight{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}.journey-highlight:last-child{border-bottom:none}.highlight-marker{width:32px;height:32px;border-radius:50%;color:#fff;font-weight:600;font-size:.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.highlight-content{flex:1}.highlight-title{font-weight:600;color:var(--maroon);margin-bottom:4px}.highlight-scene{font-size:.85rem;color:var(--text-secondary)}.relationships-list{list-style:none;padding:0;margin:0}.relationship-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.relationship-item:last-child{border-bottom:none}.relationship-type{font-weight:600;color:var(--text-primary);min-width:80px}.relationship-arrow{color:var(--saffron)}.relationship-name{color:var(--maroon);font-weight:500}@media (max-width: 480px){.character-panel-header{padding:16px}.character-panel-header h2{font-size:1.2rem}.character-panel-sanskrit{display:none}.character-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px}.character-card{padding:12px}.character-card-icon{width:40px;height:40px;font-size:1.2rem}.character-card-name{font-size:.85rem}.character-hero{padding:30px 16px}.character-hero-name{font-size:1.5rem}.character-section{padding:16px}}@media (prefers-reduced-motion: reduce){.character-card:hover,.story-appearance-card:hover{transform:none}}@media (hover: none) and (pointer: coarse){.character-card,.faction-btn,.character-search,.character-close-btn,.character-back-btn,.story-appearance-card,.search-clear-btn{min-height:44px}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:linear-gradient(135deg,var(--maroon) 0%,var(--maroon-light) 100%);padding:8px 16px;padding-bottom:max(8px,env(safe-area-inset-bottom));z-index:999;box-shadow:0 -4px 20px #0000004d}.mobile-nav-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:none;border:none;color:var(--cream);padding:8px 12px;cursor:pointer;transition:all var(--transition-fast);min-height:44px;min-width:44px;position:relative;flex:1}.mobile-nav-btn:hover{color:var(--gold)}.mobile-nav-btn:focus-visible{outline:var(--focus-ring-width) solid var(--gold);outline-offset:var(--focus-ring-offset);border-radius:8px}.mobile-nav-btn:active{transform:scale(.95)}.mobile-nav-btn.featured{background:var(--saffron);border-radius:12px;color:#fff;flex:1.2;min-height:52px}.mobile-nav-btn.featured:hover{background:var(--saffron-dark)}.mobile-nav-btn.featured:focus-visible{outline:var(--focus-ring-width) solid white;outline-offset:var(--focus-ring-offset)}.mobile-nav-icon{font-size:1.3rem}.mobile-nav-btn.featured .mobile-nav-icon{font-size:1.5rem}.mobile-nav-label{font-size:.7rem;font-weight:500}.nav-indicator{position:absolute;top:0;left:50%;transform:translate(-50%);width:20px;height:3px;background:var(--gold);border-radius:0 0 3px 3px}@media (max-width: 768px){.mobile-nav{display:flex;justify-content:space-around;align-items:center}}@media (max-width: 480px){.mobile-nav{padding:6px 8px;padding-bottom:max(6px,env(safe-area-inset-bottom))}.mobile-nav-btn{padding:6px 8px;min-width:40px}.mobile-nav-btn.featured{min-height:48px}.mobile-nav-icon{font-size:1.1rem}.mobile-nav-btn.featured .mobile-nav-icon{font-size:1.3rem}.mobile-nav-label{font-size:.65rem}}@media (hover: none) and (pointer: coarse){.mobile-nav-btn{min-height:44px;min-width:44px}.mobile-nav-btn.featured{min-height:52px}}@media (prefers-reduced-motion: reduce){.mobile-nav-btn:active{transform:none}}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg-primary)}.intro-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.intro-content{background:linear-gradient(135deg,var(--cream) 0%,var(--bg-secondary) 100%);padding:40px;border-radius:20px;max-width:600px;text-align:center;border:3px solid var(--gold);box-shadow:0 20px 60px #00000080}.intro-logo{width:100px;height:100px;object-fit:contain;border-radius:50%;margin-bottom:16px;filter:drop-shadow(0 0 12px rgba(218,165,32,.5));animation:logoPulse 3s ease-in-out infinite}@keyframes logoPulse{0%,to{filter:drop-shadow(0 0 12px rgba(218,165,32,.4))}50%{filter:drop-shadow(0 0 24px rgba(218,165,32,.7))}}.intro-content h1{font-size:2.5rem;color:var(--maroon);margin-bottom:8px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.intro-content h2{font-size:1.5rem;color:var(--saffron-dark);margin-bottom:20px;font-family:Noto Sans Devanagari,sans-serif}.intro-content p{font-size:1.1rem;color:var(--text-on-cream);margin-bottom:30px;line-height:var(--leading-relaxed)}.features{display:flex;justify-content:center;gap:30px;margin-bottom:30px;flex-wrap:wrap}.feature{display:flex;flex-direction:column;align-items:center;gap:8px}.feature-icon{font-size:2rem}.feature span:last-child{font-size:.9rem;color:var(--text-on-cream)}.start-btn{padding:16px 40px;background:linear-gradient(135deg,var(--saffron) 0%,var(--saffron-dark) 100%);color:#fff;border:none;border-radius:50px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 15px #e6730066;min-height:44px}.start-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #e6730099}.start-btn:focus-visible{outline:var(--focus-ring-width) solid var(--gold);outline-offset:var(--focus-ring-offset)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:linear-gradient(135deg,var(--maroon) 0%,var(--maroon-light) 100%);color:#fff;box-shadow:0 2px 10px #0000004d;z-index:100}.header-left{display:flex;align-items:center;gap:12px}.header-logo{width:38px;height:38px;object-fit:contain;border-radius:50%;filter:drop-shadow(0 0 6px rgba(218,165,32,.4));transition:filter var(--transition-fast)}.header-logo:hover{filter:drop-shadow(0 0 10px rgba(218,165,32,.7))}.header-text h1{color:var(--gold);margin:0;font-size:1.5rem;line-height:1.2}.subtitle{font-size:.85rem;opacity:.9}.header-right{display:flex;gap:12px}.toggle-btn,.intro-btn{padding:8px 16px;background:rgba(255,255,255,.1);border:2px solid var(--gold);color:#fff;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all var(--transition-fast);min-height:36px}.toggle-btn:hover,.intro-btn:hover{background:var(--gold);color:var(--maroon)}.toggle-btn:focus-visible,.intro-btn:focus-visible{outline:var(--focus-ring-width) solid white;outline-offset:var(--focus-ring-offset)}.toggle-btn.active,.journey-btn.active,.characters-btn.active{background:var(--gold);color:var(--maroon)}.app-main{display:flex;flex:1;overflow:hidden}.map-section{flex:1;position:relative;transition:all var(--transition-normal)}.map-section.full-width,.map-section.with-timeline{flex:1}.timeline-section{border-left:3px solid var(--border);overflow:hidden;display:flex;flex-direction:column;height:100%;max-height:100%}@media (min-width: 1025px){.timeline-section{min-width:400px;max-width:450px;height:100%;overflow:hidden}.timeline-section>div{display:flex;flex-direction:column;height:100%;max-height:100%;overflow:hidden}}.app-footer{padding:8px 24px;background:var(--maroon);color:var(--gold);text-align:center;font-size:.9rem}.sanskrit-footer{font-family:Noto Sans Devanagari,sans-serif;margin-left:8px;opacity:.9}@media (max-width: 1024px){.app-main{flex-direction:column}.map-section{height:65vh;min-height:400px}.timeline-section{height:35vh;border-left:none;border-top:3px solid var(--border);width:100%!important}.intro-content{padding:30px 20px;margin:10px;max-height:90vh;overflow-y:auto}.intro-content h1{font-size:1.6rem}.intro-content h2{font-size:1.2rem}.features{gap:15px;flex-direction:row;flex-wrap:wrap}.feature{font-size:.8rem;min-width:80px}.feature-icon{font-size:1.5rem}}@media (max-width: 768px){.app-header{padding:8px 12px;flex-wrap:wrap;gap:8px}.header-text h1{font-size:1rem;margin:0}.header-logo{width:30px;height:30px}.intro-logo{width:80px;height:80px}.subtitle{display:none}.header-right{gap:8px;flex-wrap:wrap;justify-content:flex-end}.toggle-btn,.intro-btn{padding:6px 10px;font-size:.75rem;border-width:1px;min-height:44px}.map-section{height:50vh;min-height:350px}.timeline-section{height:50vh;width:100%!important}.intro-modal{padding:20px 10px 10px;align-items:flex-start}.intro-content{padding:20px 16px;margin:0;border-radius:12px;border-width:2px}.intro-content h1{font-size:1.4rem;margin-bottom:4px}.intro-content h2{font-size:1rem;margin-bottom:12px}.intro-content p{font-size:.9rem;margin-bottom:20px}.features{flex-direction:row;gap:10px;margin-bottom:20px}.feature{flex:1;min-width:70px;font-size:.7rem}.feature-icon{font-size:1.5rem}.start-btn{padding:12px 24px;font-size:.95rem;width:100%;max-width:280px}.app-footer{padding:6px 12px;font-size:.75rem}.sanskrit-footer{display:block;margin-top:4px;margin-left:0}}@media (max-width: 480px){.app-header{padding:6px 10px}.header-text h1{font-size:.9rem}.header-logo{width:26px;height:26px}.intro-logo{width:64px;height:64px}.header-right{width:100%;justify-content:space-between}.toggle-btn,.intro-btn{flex:1;text-align:center;padding:5px 8px;font-size:.7rem;min-height:44px}.map-section{height:45vh;min-height:300px}.timeline-section{height:55vh}.intro-content h1{font-size:1.2rem}.intro-content h2{font-size:.9rem}.intro-content p{font-size:.85rem}.features{gap:8px}.feature{min-width:60px}.feature-icon{font-size:1.2rem}.start-btn{padding:10px 20px;font-size:.9rem}}@media (hover: none) and (pointer: coarse){.toggle-btn,.intro-btn,.start-btn,.era-button,.timeline-event,.event-card{min-height:44px}}@media print{.app-header,.app-footer,.intro-modal,.timeline-section{display:none}.map-section{height:100vh}}.onboarding-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);z-index:10002;pointer-events:none}.onboarding-spotlight{position:absolute;border:3px solid var(--gold);border-radius:8px;box-shadow:0 0 0 9999px #000000b3;pointer-events:auto}.onboarding-tooltip{position:fixed;background:var(--maroon);color:#fff;padding:16px 20px;border-radius:12px;max-width:300px;box-shadow:0 4px 20px #0000004d;z-index:10003;pointer-events:auto}.onboarding-tooltip h3{color:var(--gold);margin:0 0 8px;font-size:1.1rem}.onboarding-tooltip p{margin:0 0 16px;font-size:.9rem;line-height:1.5}.onboarding-tooltip-buttons{display:flex;gap:10px;justify-content:flex-end}.onboarding-btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all var(--transition-fast);min-height:44px}.onboarding-btn-secondary{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.3)}.onboarding-btn-secondary:hover{background:rgba(255,255,255,.2)}.onboarding-btn-primary{background:var(--gold);color:var(--maroon)}.onboarding-btn-primary:hover{background:var(--saffron)}.onboarding-btn:focus-visible{outline:2px solid white;outline-offset:2px}.onboarding-dots{display:flex;gap:6px;justify-content:center;margin-bottom:12px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3)}.onboarding-dot.active{background:var(--gold)}.onboarding-dot.completed{background:rgba(255,215,0,.5)}.onboarding-tooltip-mobile{position:fixed!important;left:50%!important;bottom:80px!important;top:auto!important;transform:translate(-50%)!important;width:calc(100vw - 40px);max-width:340px}.tutorial-btn{animation:tutorialPulse 2.5s ease-in-out 3}@keyframes tutorialPulse{0%,to{box-shadow:0 0 #daa52000}50%{box-shadow:0 0 0 6px #daa52059}}@media (max-width: 768px){.onboarding-tooltip{max-width:calc(100vw - 32px);padding:14px 16px;border-radius:10px}.onboarding-tooltip h3{font-size:1rem}.onboarding-tooltip p{font-size:.85rem}.onboarding-tooltip-buttons{flex-wrap:wrap;gap:8px}}.reading-progress-bar{position:absolute;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--saffron),var(--gold));transition:width var(--transition-normal)}.map-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--cream);z-index:1000}.map-loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--saffron);border-radius:50%;animation:spin 1s linear infinite}.map-loading-text{margin-top:16px;font-family:Cinzel,serif;color:var(--maroon);font-size:1rem}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:40px;text-align:center;background:var(--bg-secondary);border-radius:12px;border:2px solid var(--battlefield)}.error-boundary h2{color:var(--battlefield);margin-bottom:16px}.error-boundary p{color:var(--text-secondary);margin-bottom:24px}.error-boundary button{padding:12px 24px;background:var(--maroon);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:background var(--transition-fast);min-height:44px}.error-boundary button:hover{background:var(--maroon-light)}.error-boundary button:focus-visible{outline:var(--focus-ring-width) solid var(--saffron);outline-offset:var(--focus-ring-offset)}@media (prefers-reduced-motion: reduce){.start-btn:hover,.toggle-btn:hover,.intro-btn:hover,.onboarding-btn:hover{transform:none}.map-loading-spinner{animation:none}}*{margin:0;padding:0;box-sizing:border-box}:root{--saffron: #FF9933;--saffron-dark: #E67300;--maroon: #800000;--maroon-light: #A52A2A;--gold: #FFD700;--gold-dark: #DAA520;--cream: #FFF8DC;--cream-dark: #F5DEB3;--charcoal: #36454F;--black: #1a1a1a;--bg-primary: var(--cream);--bg-secondary: var(--cream-dark);--text-primary: var(--charcoal);--text-secondary: #555;--accent: var(--saffron);--accent-dark: var(--saffron-dark);--border: var(--gold-dark);--text-on-cream: #2d2d2d;--text-on-maroon: #FFD700;--text-on-saffron: #1a1a1a;--gold-text: #B8860B;--kingdom: #FFD700;--battlefield: #DC143C;--sacred: #9370DB;--forest: #228B22;--site: #8B4513;--village: #DEB887;--mountain: #708090;--divine: #00BFFF;--asura: #8B0000;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--focus-ring-color: var(--saffron);--focus-ring-offset: 2px;--focus-ring-width: 3px;--transition-fast: .15s;--transition-normal: .3s;--transition-slow: .5s}@media (prefers-reduced-motion: reduce){:root{--transition-fast: 0s;--transition-normal: 0s;--transition-slow: 0s}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:Noto Sans Devanagari,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:Cinzel,serif;color:var(--maroon);margin-bottom:.5rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-dark)}.map-container{width:100%;height:100%;background:var(--cream-dark)}.custom-marker{background:none;border:none}.marker-container{width:30px;height:30px;border-radius:50%;border:3px solid white;box-shadow:0 2px 8px #0006;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s}.marker-container:hover{transform:scale(1.2);box-shadow:0 4px 12px #00000080}.marker-container.selected{transform:scale(1.3);box-shadow:0 0 0 4px var(--gold),0 4px 16px #0009;z-index:1000!important}.leaflet-popup-content-wrapper{background:var(--bg-primary);border:2px solid var(--border);border-radius:8px;font-family:Noto Sans Devanagari,sans-serif}.leaflet-popup-tip{background:var(--border)}.leaflet-popup-content h3{margin:0 0 8px;color:var(--maroon);font-size:1.1rem}.leaflet-popup-content p{margin:0;font-size:.9rem;color:var(--text-secondary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.animate-fadeIn{animation:fadeIn .3s ease-out}.animate-slideIn{animation:slideIn .3s ease-out}.animate-pulse{animation:pulse 2s infinite}@media (max-width: 768px){.marker-container{width:28px;height:28px;font-size:13px;border-width:2px}.marker-container:hover{transform:scale(1.1)}.marker-container.selected{transform:scale(1.2);box-shadow:0 0 0 3px var(--gold),0 3px 12px #00000080}}@media (max-width: 480px){.marker-container{width:26px;height:26px;font-size:12px}}@media (hover: none) and (pointer: coarse){.marker-container{width:32px;height:32px;font-size:14px}.marker-container:active{transform:scale(1.1)}}.loading{display:flex;align-items:center;justify-content:center;height:100%;font-family:Cinzel,serif;font-size:1.5rem;color:var(--maroon)}.loading:after{content:"";width:20px;height:20px;margin-left:10px;border:2px solid var(--accent);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:focus{outline:none}:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}button:focus-visible,a:focus-visible,[role=button]:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.dark-focus:focus-visible{outline-color:var(--gold)}.skip-link{position:absolute;top:-40px;left:0;background:var(--maroon);color:var(--gold);padding:8px 16px;z-index:10001;text-decoration:none;font-weight:600;transition:top .2s}.skip-link:focus{top:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.visually-hidden{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 (prefers-reduced-motion: reduce){.animate-fadeIn,.animate-slideIn,.animate-pulse{animation:none!important}.loading:after{animation:none!important}.marker-container,.marker-container:hover,.marker-container.selected{transition:none!important;transform:none!important}}@media (max-width: 768px){.leaflet-popup-content-wrapper{max-width:280px;min-width:200px}.leaflet-popup-content{margin:8px 12px;max-width:260px}.leaflet-popup-content h3{font-size:1rem;margin:0 0 6px}.leaflet-popup-content p{font-size:.85rem;line-height:1.4}.leaflet-container a.leaflet-popup-close-button{width:44px;height:44px;font-size:20px;line-height:44px;padding:0;text-align:center}}@media (max-width: 480px){.leaflet-popup-content-wrapper{max-width:240px;min-width:180px}.leaflet-popup-content{margin:6px 10px;max-width:220px}.leaflet-popup-content h3{font-size:.9rem}.leaflet-popup-content p{font-size:.8rem}}
