:root{--background: rgb(38, 31, 22);--foreground: rgb(245, 235, 210);--card: rgb(37, 31, 23);--card-strong: rgb(52, 42, 29);--primary-foreground: rgb(38, 31, 22);--secondary: rgb(61, 51, 37);--muted-foreground: rgb(178, 160, 123);--border: rgb(111, 82, 45);--gold: rgb(226, 187, 98);--gold-dark: rgb(181, 135, 49);--parchment: rgb(235, 222, 168);--radius: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;font-family:Cinzel,Georgia,serif;color:var(--foreground);background:var(--background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}::selection{color:var(--primary-foreground);background:var(--gold)}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:var(--card)}::-webkit-scrollbar-thumb{background:var(--border);border:2px solid var(--card);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--gold-dark)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit}svg{width:1.25rem;height:1.25rem;fill:currentColor}.app-shell{position:relative;min-height:100vh;overflow:hidden;background:var(--background);color:var(--foreground)}.texture-overlay{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.05;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E")}.pixel-art{image-rendering:pixelated;image-rendering:crisp-edges}.site-header{position:fixed;top:0;left:0;right:0;z-index:50}.top-glint,.bottom-glint,.medieval-divider{background:linear-gradient(90deg,transparent 0%,var(--gold-dark) 20%,var(--gold) 50%,var(--gold-dark) 80%,transparent 100%)}.top-glint,.bottom-glint{height:2px}.nav-panel{position:relative;display:grid;grid-template-columns:minmax(1rem,1fr) minmax(16rem,28rem) minmax(34rem,52rem) minmax(1rem,1fr);align-items:center;height:4.1rem;min-height:4.1rem;padding:0;background:radial-gradient(circle at 50% -80%,rgba(181,135,49,.16),transparent 34rem),linear-gradient(180deg,#250f06fa,#1b0a05fa);border-left:2px solid var(--border);border-right:2px solid var(--border);box-shadow:inset 0 1px #e2bb622e,inset 0 -1px #00000080,0 7px 20px #00000073}.nav-brand,.desktop-nav,.mobile-toggle{position:relative;z-index:2;align-self:center}.nav-brand{display:inline-flex;align-items:center;grid-column:2;gap:.9rem;width:max-content;justify-self:start;color:var(--gold);font-size:1.28rem;font-weight:800;letter-spacing:.08em;line-height:1;text-transform:uppercase;transition:filter .25s ease}.nav-brand:hover{filter:drop-shadow(0 0 10px rgba(226,187,98,.65))}.nav-brand svg,.footer-brand svg{width:2.35rem;height:2.35rem}.nav-brand path,.footer-brand path{fill:url(#shieldGradient);stroke:var(--gold);stroke-width:2}.nav-brand text,.footer-brand text{fill:var(--gold);font-size:14px;font-family:Georgia,serif;font-weight:800}.desktop-nav{display:flex;align-items:center;grid-column:3;justify-content:flex-end;gap:1.35rem;line-height:1}.desktop-nav a:not(.nav-play){position:relative;display:inline-flex;align-items:center;padding:.5rem .15rem;color:#f5ebd2bd;font-size:.96rem;font-weight:500;letter-spacing:.02em;text-transform:uppercase;transition:color .25s ease}.desktop-nav a:not(.nav-play):before,.desktop-nav a:not(.nav-play):after{content:"";position:absolute;left:50%;transform:translate(-50%);transition:width .25s ease,background .25s ease}.desktop-nav a:not(.nav-play):before{display:none}.desktop-nav a:not(.nav-play):after{bottom:.05rem;width:0;height:2px;background:var(--gold)}.desktop-nav a:not(.nav-play):hover{color:var(--gold)}.desktop-nav a:not(.nav-play):hover:before{background:transparent}.desktop-nav a:not(.nav-play):hover:after{width:75%}.nav-play,.button{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;border-radius:var(--radius);border:2px solid var(--gold);font-weight:800;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease}.nav-play{align-self:center;min-width:8.4rem;height:2.75rem;min-height:2.75rem;margin-left:.9rem;padding:.55rem 1.35rem;color:var(--primary-foreground);background:linear-gradient(180deg,#f0bf1c,#bd8200);border-color:#d49b07;border-radius:.28rem;box-shadow:inset 0 1px #ffeb846b,0 0 0 1px #0000003d,0 4px 10px #00000061;font-size:.9rem;line-height:1;text-transform:uppercase}.nav-play:hover,.button-primary:hover{transform:scale(1.05);box-shadow:0 0 20px #e2bb6273,0 0 40px #e2bb6238}.mobile-toggle{display:none;justify-self:end;border:0;color:var(--foreground);background:transparent;cursor:pointer}.mobile-nav{position:absolute;top:100%;left:0;right:0;grid-column:1 / -1;max-height:0;overflow:hidden;transition:max-height .3s ease,border-color .3s ease;border-top:1px solid transparent;background:linear-gradient(180deg,#1b0a05fa,#250f06fa)}.mobile-nav.open{max-height:20rem;border-color:var(--border)}.mobile-nav a{display:block;padding:.9rem 1rem;color:#f5ebd2cc;border-radius:var(--radius)}.mobile-nav a:hover{color:var(--gold);background:#e2bb621a}.hero-section{position:relative;display:flex;min-height:100vh;align-items:center;justify-content:center;overflow:hidden;padding:7rem 1rem 4rem}.hero-background,.hero-background img,.hero-background video,.hero-shade,.hero-vignette{position:absolute;inset:0}.hero-background img,.hero-background video{width:100%;height:100%;object-fit:cover}.hero-background video{filter:saturate(.9) contrast(1.08)}.hero-shade{background:linear-gradient(180deg,rgba(38,31,22,.74) 0%,rgba(38,31,22,.42) 45%,var(--background) 100%)}.hero-vignette{background:radial-gradient(ellipse at center,transparent 0%,rgba(38,31,22,.85) 100%)}.hero-inner{position:relative;z-index:2;max-width:56rem;margin:0 auto;padding-top:1rem;text-align:center;opacity:0;transform:translateY(2.5rem);transition:opacity 1s ease,transform 1s ease}.hero-inner.is-visible{opacity:1;transform:translateY(0)}.hero-ornament{width:12rem;height:2rem;margin:0 auto 1.5rem}.hero-ornament path,.section-header svg path{fill:none;stroke:var(--gold-dark);stroke-width:2}.hero-ornament circle{fill:var(--gold)}.hero-logo-wrap{display:flex;justify-content:center;margin:0 auto 1.5rem}.hero-logo{width:min(42rem,92vw);max-height:24rem;object-fit:contain;filter:drop-shadow(0 0 22px rgba(226,187,98,.35)) drop-shadow(0 18px 24px rgba(0,0,0,.5));-webkit-user-select:none;user-select:none}.subtitle-row{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.subtitle-row span,.spark-row span{width:4rem;height:2px;background:linear-gradient(90deg,transparent,var(--gold))}.subtitle-row span:last-child,.spark-row span:last-child{background:linear-gradient(90deg,var(--gold),transparent)}.subtitle-row p{margin:0;color:var(--gold-dark);font-size:.9rem;letter-spacing:.32em;text-transform:uppercase}.hero-copy{max-width:42rem;margin:0 auto 2.5rem;color:#f5ebd2e6;font-size:clamp(1.08rem,2vw,1.45rem);line-height:1.65;text-wrap:balance}.hero-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem}.button{min-height:3.5rem;padding:.95rem 2rem;cursor:pointer}.button svg{width:1.25rem;height:1.25rem}.button-primary{color:var(--primary-foreground);background:linear-gradient(180deg,var(--gold) 0%,var(--gold-dark) 100%);font-size:1.05rem}.button-secondary{color:var(--foreground);background:#3d332580;border-color:var(--border)}.button-secondary:hover{border-color:var(--gold);background:#3d3325f2}.button.compact{min-height:2.6rem;padding:.6rem 1.2rem;color:var(--gold);background:var(--secondary);border-color:#b5873180}.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.game-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:2rem;margin-top:3rem;color:var(--muted-foreground);font-size:.95rem}.game-stats span{display:inline-flex;align-items:center;gap:.5rem}.game-stats i{display:inline-block;width:.55rem;height:.55rem;border-radius:999px;background:#22c55e;animation:blink 1.8s ease-in-out infinite}.game-stats b{color:var(--gold)}.scroll-cue{position:absolute;left:50%;bottom:2rem;z-index:2;color:#e2bb62a6;transform:translate(-50%);animation:bounce 1.5s infinite}.scroll-cue:hover{color:var(--gold)}.scroll-cue svg{width:2rem;height:2rem}.section{position:relative;z-index:1;padding:6rem 1rem}.features-section:before{content:"";position:absolute;inset:0;opacity:.05;background-image:repeating-linear-gradient(45deg,var(--gold) 0,var(--gold) 1px,transparent 1px,transparent 20px)}.world-section{background:linear-gradient(180deg,var(--background),rgba(61,51,37,.2),var(--background))}.section-header{max-width:48rem;margin:0 auto 4rem;text-align:center}.section-header h2,.cta-card h2{margin:1rem 0;color:var(--gold);font-size:clamp(2rem,5vw,3.2rem);font-weight:800;letter-spacing:.05em;line-height:1.1;text-shadow:0 0 10px rgba(226,187,98,.45)}.section-header p,.cta-card p{margin:0 auto;max-width:42rem;color:var(--muted-foreground);font-size:1.125rem;line-height:1.7}.medieval-divider{height:2px;margin:0 auto}.medieval-divider.small{width:6rem}.section-header svg{width:8rem;height:1.5rem}.section-header svg.flipped{transform:rotate(180deg)}.features-grid,.gallery-grid,.footer-grid{display:grid;max-width:80rem;margin:0 auto;gap:1.5rem}.features-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.medieval-frame,.feature-card{position:relative;border:3px solid var(--gold-dark);background:linear-gradient(135deg,var(--card-strong) 0%,var(--card) 50%,#1d1913 100%);box-shadow:inset 0 0 0 1px var(--border),inset 0 0 20px #00000080,0 4px 15px #0006}.feature-card{display:flex;gap:1.5rem;min-height:13rem;overflow:hidden;padding:2rem;border-radius:var(--radius-lg);animation:rise-in .7s ease both;transition:transform .25s ease}.feature-card:hover{transform:scale(1.02)}.feature-card:before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .25s ease}.feature-card:hover:before{opacity:1}.tone-ember:before,.tone-ember .feature-icon{background:linear-gradient(135deg,#ef444433,#f9731633)}.tone-aether:before,.tone-aether .feature-icon{background:linear-gradient(135deg,#3b82f633,#06b6d433)}.tone-verdant:before,.tone-verdant .feature-icon{background:linear-gradient(135deg,#22c55e33,#10b98133)}.tone-gold:before,.tone-gold .feature-icon{background:linear-gradient(135deg,#f59e0b33,#eab30833)}.feature-icon{position:relative;z-index:1;display:grid;flex:0 0 auto;width:4rem;height:4rem;place-items:center;border:1px solid rgba(226,187,98,.3);border-radius:var(--radius-lg);color:var(--gold);transition:box-shadow .25s ease}.feature-card:hover .feature-icon{box-shadow:0 0 20px #e2bb6266,0 0 40px #e2bb6233}.feature-icon svg{width:2rem;height:2rem}.feature-card h3,.city-content h3,.lightbox-card h3{position:relative;z-index:1;margin:0 0 .6rem;color:var(--foreground);font-size:1.55rem;transition:color .25s ease}.feature-card:hover h3{color:var(--gold)}.feature-card p,.city-content p,.gallery-caption small,.footer p,.footer a,.lightbox-card p{position:relative;z-index:1;margin:0;color:var(--muted-foreground);line-height:1.65}.corner{position:absolute;z-index:3;width:1rem;height:1rem;border-color:#e2bb6259;pointer-events:none}.corner.large{width:2rem;height:2rem}.top-left{top:.5rem;left:.5rem;border-top:2px solid;border-left:2px solid;border-top-left-radius:.25rem}.top-right{top:.5rem;right:.5rem;border-top:2px solid;border-right:2px solid;border-top-right-radius:.25rem}.bottom-left{bottom:.5rem;left:.5rem;border-bottom:2px solid;border-left:2px solid;border-bottom-left-radius:.25rem}.bottom-right{right:.5rem;bottom:.5rem;border-right:2px solid;border-bottom:2px solid;border-bottom-right-radius:.25rem}.city-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:2rem}.city-tabs button{padding:.8rem 1.5rem;color:var(--foreground);background:#3d332580;border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;font-weight:700;transition:all .25s ease}.city-tabs button:hover{border-color:#e2bb6280;background:var(--secondary)}.city-tabs button.active{color:var(--primary-foreground);background:linear-gradient(180deg,var(--gold) 0%,var(--gold-dark) 100%);border-color:var(--gold);box-shadow:0 0 20px #e2bb6266,0 0 40px #e2bb6233}.city-panel{display:grid;grid-template-columns:1fr 1fr;max-width:80rem;margin:0 auto;overflow:hidden;border-radius:var(--radius-xl)}.city-image{position:relative;min-height:25rem}.city-image:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(38,31,22,.5))}.city-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease}.city-image img.active{opacity:1}.city-content{display:grid;grid-template-columns:.35rem 1fr;gap:1rem;align-items:start;padding:clamp(1.5rem,4vw,2.5rem)}.city-marker{width:.35rem;height:2rem;margin-top:.25rem;border-radius:999px;background:var(--gold)}.city-content h3{color:var(--gold);font-size:clamp(2rem,4vw,2.8rem)}.city-subtitle{margin-bottom:1.3rem!important;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase}.city-content h4{margin:1.5rem 0 .75rem;color:var(--gold-dark);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase}.location-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.location-tags span{padding:.35rem .75rem;color:#f5ebd2d1;background:#3d332580;border:1px solid var(--border);border-radius:calc(var(--radius) - .15rem);font-size:.9rem}.city-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.5rem}.city-dots button{width:.55rem;height:.55rem;padding:0;border:0;border-radius:999px;background:#e2bb624d;cursor:pointer;transition:width .25s ease,background .25s ease}.city-dots button.active{width:2rem;background:var(--gold)}.gallery-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.gallery-card{position:relative;display:block;aspect-ratio:4 / 3;overflow:hidden;padding:0;border-radius:var(--radius-lg);cursor:pointer}.gallery-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.gallery-card:hover img{transform:scale(1.1)}.gallery-overlay{position:absolute;inset:0;opacity:0;background:linear-gradient(180deg,transparent,rgba(38,31,22,.9));transition:opacity .25s ease}.gallery-card:hover .gallery-overlay{opacity:1}.gallery-caption{position:absolute;right:0;bottom:0;left:0;z-index:2;display:grid;gap:.25rem;padding:1rem;text-align:left;transform:translateY(100%);transition:transform .25s ease}.gallery-card:hover .gallery-caption{transform:translateY(0)}.gallery-caption strong{color:var(--gold);font-size:1rem}.cta-section{overflow:hidden;background:linear-gradient(180deg,var(--background),rgba(61,51,37,.3),var(--background))}.particle-field{position:absolute;inset:0;overflow:hidden;pointer-events:none}.particle{position:absolute;width:.25rem;height:.25rem;border-radius:999px;background:#e2bb626b;animation:float 4s ease-in-out infinite}.particle-1{left:8%;top:24%;animation-delay:.1s}.particle-2{left:15%;top:72%;animation-delay:1.3s;animation-duration:5s}.particle-3{left:23%;top:38%;animation-delay:2.1s}.particle-4{left:31%;top:84%;animation-delay:.7s;animation-duration:6s}.particle-5{left:39%;top:18%;animation-delay:1.8s}.particle-6{left:46%;top:64%;animation-delay:.4s;animation-duration:5.5s}.particle-7{left:52%;top:31%;animation-delay:2.7s}.particle-8{left:61%;top:77%;animation-delay:1.1s}.particle-9{left:68%;top:12%;animation-delay:3s;animation-duration:6.2s}.particle-10{left:76%;top:55%;animation-delay:1.9s}.particle-11{left:84%;top:26%;animation-delay:.8s}.particle-12{left:91%;top:82%;animation-delay:2.4s;animation-duration:4.8s}.particle-13{left:5%;top:48%;animation-delay:3.2s}.particle-14{left:18%;top:14%;animation-delay:2.9s}.particle-15{left:27%;top:61%;animation-delay:1.6s}.particle-16{left:57%;top:91%;animation-delay:.2s}.particle-17{left:72%;top:39%;animation-delay:2.2s}.particle-18{left:80%;top:69%;animation-delay:1.4s}.particle-19{left:88%;top:9%;animation-delay:.6s}.particle-20{left:96%;top:46%;animation-delay:3.4s}.cta-card{max-width:56rem;margin:0 auto;padding:clamp(2rem,5vw,4rem);border-radius:1rem;text-align:center}.spark-row{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem;color:var(--gold)}.spark-row svg{width:1.6rem;height:1.6rem;animation:blink 2s ease-in-out infinite}.cta-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin:2.5rem 0}.cta-stats div{min-width:7rem}.cta-stats b{display:block;color:var(--gold);font-size:2rem}.cta-stats span{color:var(--muted-foreground);font-size:.9rem}.cta-stats i{width:1px;min-height:3rem;background:var(--border)}.trust-row{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:2.5rem;color:var(--muted-foreground);font-size:.95rem}.trust-row span{display:inline-flex;align-items:center;gap:.45rem}.trust-row svg{color:#22c55e}.footer{position:relative;z-index:1;padding:4rem 1rem 2rem;border-top:1px solid var(--border)}.footer:before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(0deg,rgba(61,51,37,.3),transparent)}.footer-inner{position:relative;z-index:1;max-width:80rem;margin:0 auto}.footer-grid{grid-template-columns:1.5fr repeat(4,1fr);margin-bottom:3rem}.footer-brand a{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:var(--gold);font-size:1.1rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase}.footer-brand p{max-width:16rem;margin-bottom:1rem;font-size:.92rem}.social-links{display:flex;gap:.75rem}.social-links a{display:grid;width:2.25rem;height:2.25rem;place-items:center;color:var(--muted-foreground);background:#3d332580;border:1px solid var(--border);border-radius:var(--radius);transition:color .25s ease,border-color .25s ease,background .25s ease}.social-links a:hover,.footer-column a:hover{color:var(--gold);border-color:var(--gold)}.footer-column{display:grid;align-content:start;gap:.5rem}.footer-column h3{margin:0 0 .5rem;color:var(--gold);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase}.footer-column a{font-size:.92rem;transition:color .25s ease}.footer-bottom{display:flex;justify-content:space-between;gap:1rem;padding-top:2rem;color:var(--muted-foreground);font-size:.9rem}.lightbox{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem;background:#261f16f5}.lightbox-inner{position:relative;width:min(64rem,100%)}.lightbox-close{position:absolute;right:0;top:-3rem;border:0;color:#f5ebd2a6;background:transparent;cursor:pointer}.lightbox-close:hover{color:var(--gold)}.lightbox-card{overflow:hidden;border-radius:var(--radius-xl)}.lightbox-card img{display:block;width:100%;aspect-ratio:16 / 9;object-fit:cover}.lightbox-card div{padding:1rem;border-top:1px solid var(--border);background:#3d332580}.lightbox-card h3{color:var(--gold)}.lightbox-arrow{position:absolute;top:50%;display:grid;width:3rem;height:3rem;place-items:center;border:1px solid var(--border);border-radius:999px;color:var(--foreground);background:#3d3325db;cursor:pointer;transform:translateY(-50%)}.lightbox-arrow:hover{color:var(--gold);border-color:var(--gold)}.lightbox-arrow.left{left:1rem}.lightbox-arrow.right{right:1rem}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #e2bb6266}50%{box-shadow:0 0 35px #e2bb62a6}}@keyframes blink{0%,to{opacity:1}50%{opacity:.45}}@keyframes bounce{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,.5rem)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-.75rem)}}@keyframes rise-in{0%{opacity:0;transform:translateY(2rem)}to{opacity:1;transform:translateY(0)}}@media(max-width:920px){.nav-panel{grid-template-columns:1fr auto;padding:0 1rem}.nav-brand{grid-column:1}.desktop-nav{display:none}.mobile-toggle{display:grid;place-items:center}.features-grid,.city-panel,.gallery-grid,.footer-grid{grid-template-columns:1fr}.city-image{min-height:20rem}.city-image:after{background:linear-gradient(0deg,rgba(38,31,22,.78),transparent)}}@media(max-width:640px){.nav-brand span{font-size:1rem}.hero-section{padding-top:6rem}.hero-logo{width:min(30rem,92vw);max-height:18rem}.subtitle-row{gap:.7rem}.subtitle-row span,.spark-row span{width:2.5rem}.hero-actions,.button{width:100%}.game-stats{gap:.8rem}.section{padding:4.5rem 1rem}.feature-card{flex-direction:column;padding:1.5rem}.city-tabs{gap:.5rem}.city-tabs button{flex:1;min-width:6rem;padding:.75rem .8rem}.city-content{grid-template-columns:1fr}.city-marker,.cta-stats i{display:none}.footer-bottom{flex-direction:column}.lightbox-arrow{width:2.4rem;height:2.4rem}}
