
:root{
  --deep:#080c18;--navy:#0c1830;--blue:#183460;--accent:#2860a8;
  --teal:#187888;--gold:#c09840;--lgold:#e8c870;--cyan:#38b8d0;
  --white:#e0f0ff;--muted:#7898b8;--card:rgba(12,24,48,.88);
  --border:rgba(56,184,208,.28);--glow:rgba(56,184,208,.12);
  --ease-expo:cubic-bezier(0.16,1,0.3,1);
  --ease-back:cubic-bezier(0.34,1.56,0.64,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:70px}
body{font-family:'Raleway',sans-serif;background:var(--deep);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
@media(pointer:fine){body{cursor:none}}
img{display:block;max-width:100%}

#cur,#cur-ring{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;will-change:transform}
#cur{width:10px;height:10px;background:var(--cyan);box-shadow:0 0 14px var(--cyan);transform:translate(-50%,-50%);transition:transform .12s,background .2s}
#cur-ring{width:34px;height:34px;border:1.5px solid rgba(56,184,208,.55);transform:translate(-50%,-50%);transition:width .25s var(--ease-back),height .25s var(--ease-back),border-color .25s}
@media(pointer:coarse){#cur,#cur-ring{display:none}}

#bg{position:fixed;inset:0;z-index:0;overflow:hidden}
#bg-gif{position:absolute;inset:0;background-size:cover;background-position:center 20%;opacity:.42;}
#bg-grad{position:absolute;inset:0;background:radial-gradient(ellipse 90% 55% at 50% 0%,rgba(24,52,96,.75) 0%,transparent 70%),linear-gradient(180deg,rgba(8,12,24,.3) 0%,rgba(8,12,24,.75) 55%,rgba(8,12,24,1) 100%)}
#bg-particles{position:absolute;inset:0}
.pt{position:absolute;border-radius:50%;will-change:transform,opacity}
#ripples{position:fixed;inset:0;pointer-events:none;z-index:1}
.ripple{position:absolute;border-radius:50%;border:1px solid rgba(56,184,208,.5);animation:ripple-expand 1.8s var(--ease-expo) forwards;pointer-events:none}
@keyframes ripple-expand{from{transform:translate(-50%,-50%) scale(0);opacity:.9}to{transform:translate(-50%,-50%) scale(5);opacity:0}}
.wl{position:fixed;right:0;top:0;width:min(260px,28vw);height:100vh;pointer-events:none;z-index:2;opacity:.03;background:repeating-linear-gradient(-48deg,var(--cyan) 0,var(--cyan) 1px,transparent 1px,transparent 18px)}
.dmd{position:fixed;width:7px;height:7px;background:var(--cyan);transform:rotate(45deg);opacity:0;pointer-events:none;z-index:4;animation:dmd-fly .9s var(--ease-expo) forwards}
@keyframes dmd-fly{0%{opacity:.9;transform:rotate(45deg) translateY(0) scale(1)}100%{opacity:0;transform:rotate(45deg) translateY(-70px) scale(0)}}

nav{position:fixed;top:0;left:0;right:0;z-index:200;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1rem,4vw,3rem);background:rgba(8,12,24,.55);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);transition:background .4s,box-shadow .4s}
nav.scrolled{background:rgba(8,12,24,.92);box-shadow:0 4px 30px rgba(0,0,0,.4)}
.nav-logo{font-family:'Cinzel Decorative',serif;font-size:clamp(.8rem,2vw,1rem);color:var(--cyan);text-shadow:0 0 18px rgba(56,184,208,.6);letter-spacing:.1em;white-space:nowrap;text-decoration:none}
.nav-links{display:flex;gap:clamp(1rem,2.5vw,2rem);list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;transition:color .25s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--cyan);transform:scaleX(0);transform-origin:center;transition:transform .3s var(--ease-expo)}
.nav-links a:hover,.nav-links a.active{color:var(--cyan)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none}
.ham span{display:block;width:24px;height:2px;background:var(--cyan);border-radius:2px;transition:transform .35s var(--ease-expo),opacity .3s}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-drawer{position:fixed;top:64px;left:0;right:0;background:rgba(8,12,24,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:199;overflow:hidden;max-height:0;transition:max-height .45s var(--ease-expo)}
.nav-drawer.open{max-height:300px}
.nav-drawer ul{list-style:none;padding:1rem 1.5rem 1.5rem;display:flex;flex-direction:column;gap:.2rem}
.nav-drawer a{display:block;padding:.7rem .5rem;color:var(--muted);text-decoration:none;font-size:.9rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid rgba(56,184,208,.1);transition:color .2s,padding-left .2s}
.nav-drawer a:hover{color:var(--cyan);padding-left:1rem}
@media(max-width:768px){.nav-links{display:none}.ham{display:flex}}

.content{position:relative;z-index:10}
.section{padding:clamp(3rem,8vh,5.5rem) clamp(1rem,4vw,2rem);max-width:1200px;margin:0 auto}
.sec-head{text-align:center;margin-bottom:clamp(2rem,5vh,3.5rem)}
.sec-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.4em;color:var(--gold);font-weight:700;margin-bottom:.5rem}
.sec-title{font-family:'Cinzel Decorative',serif;font-size:clamp(1.4rem,3.5vw,2.2rem);color:var(--white);position:relative;display:inline-block}
.sec-title::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:50px;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent)}
.divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);max-width:1200px;margin:0 auto}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s var(--ease-expo),transform .65s var(--ease-expo);will-change:opacity,transform}
.reveal.vis{opacity:1;transform:translateY(0)}
footer{text-align:center;padding:2rem clamp(1rem,4vw,2rem);border-top:1px solid var(--border);color:var(--muted);font-size:.75rem;letter-spacing:.09em;position:relative;z-index:10}
.footer-sigil{display:block;font-family:'Cinzel Decorative',serif;font-size:1.1rem;color:var(--cyan);text-shadow:0 0 14px rgba(56,184,208,.5);margin-bottom:.5rem}
#tip{position:fixed;background:rgba(12,24,48,.96);border:1px solid var(--border);border-radius:8px;padding:.42rem .85rem;font-size:.73rem;color:var(--white);pointer-events:none;z-index:300;opacity:0;transform:translateY(4px);transition:opacity .2s,transform .2s;backdrop-filter:blur(12px);white-space:nowrap}
#tip.show{opacity:1;transform:translateY(0)}

.page-hero{min-height:38vh;display:flex;align-items:flex-end;padding:0 clamp(1rem,4vw,3rem) 3rem;position:relative;margin-top:64px}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(1px) saturate(1.2);opacity:.35;transform:scale(1.05)}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,12,24,.4),rgba(8,12,24,.95))}
.page-hero-content{position:relative;z-index:2;max-width:1200px;width:100%;margin:0 auto}
.page-back{cursor:pointer;display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);text-decoration:none;font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.2rem;transition:color .25s,transform .25s var(--ease-expo);border:1px solid var(--border);padding:.35rem .9rem;border-radius:20px;background:rgba(56,184,208,.05)}
.page-back:hover{color:var(--cyan);transform:translateX(-4px);border-color:var(--cyan)}
.page-game-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.68rem;text-transform:uppercase;letter-spacing:.3em;font-weight:700;margin-bottom:.6rem}
.page-title{font-family:'Cinzel Decorative',serif;font-size:clamp(2rem,6vw,3.5rem);font-weight:700;line-height:1.1;margin-bottom:.5rem}
.page-uid-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}
.uid-chip{display:inline-flex;align-items:center;gap:.35rem;background:rgba(56,184,208,.1);border:1px solid rgba(56,184,208,.3);border-radius:6px;padding:.3rem .75rem;font-size:.75rem;font-weight:700;color:var(--cyan);letter-spacing:.05em}
.uid-chip span{color:var(--muted);font-weight:400}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,160px),1fr));gap:.75rem;margin-bottom:2rem}
.stat-card{cursor:default;background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1rem 1.1rem;text-align:center;transition:transform .3s var(--ease-expo),border-color .3s;backdrop-filter:blur(10px)}
.stat-card:hover{transform:translateY(-4px);border-color:var(--gc,var(--cyan))}
.stat-val{font-family:'Orbitron',monospace;font-size:1.5rem;font-weight:700;color:var(--gc,var(--cyan));margin-bottom:.2rem}
.stat-lbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-weight:600}

.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,130px),1fr));gap:1rem}
.char-card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .38s var(--ease-expo),border-color .3s,box-shadow .38s;backdrop-filter:blur(10px)}
.char-card:hover{transform:translateY(-7px) scale(1.02);border-color:var(--cc,var(--cyan));box-shadow:0 16px 40px rgba(0,0,0,.5)}
.char-card-img{width:100%;aspect-ratio:3/4;overflow:hidden;background:linear-gradient(135deg,rgba(24,52,96,.85),rgba(24,120,136,.55));position:relative;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--muted);text-align:center}
.char-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 15%;transition:transform .45s var(--ease-expo)}
.char-card:hover .char-card-img img{transform:scale(1.07)}
.char-card-info{padding:.55rem .7rem .7rem}
.char-card-name{font-size:.78rem;font-weight:700;color:var(--white);margin-bottom:.2rem}
.char-card-badge{display:inline-block;padding:.12rem .45rem;border-radius:3px;font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--cc,rgba(56,184,208,.4));color:var(--cc,var(--cyan));background:rgba(56,184,208,.07)}

.modal-bg{position:fixed;inset:0;background:rgba(4,8,20,.85);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .35s;backdrop-filter:blur(8px)}
.modal-bg.open{opacity:1;pointer-events:all}
.modal{background:var(--navy);border:1px solid var(--border);border-radius:16px;max-width:820px;width:100%;max-height:90vh;overflow-y:auto;position:relative;transform:translateY(30px) scale(.97);transition:transform .4s var(--ease-expo);scrollbar-width:thin;scrollbar-color:var(--cyan) transparent}
.modal-bg.open .modal{transform:translateY(0) scale(1)}
.modal-close{position:sticky;top:0;z-index:10;display:flex;justify-content:flex-end;padding:.75rem 1rem;background:linear-gradient(to bottom,var(--navy) 60%,transparent)}
.modal-close button{background:rgba(56,184,208,.1);border:1px solid var(--border);color:var(--muted);width:32px;height:32px;border-radius:50%;font-size:1.1rem;cursor:pointer;transition:background .2s,color .2s}
.modal-close button:hover{background:rgba(56,184,208,.25);color:var(--white)}
.modal-body{padding:0 1.5rem 2rem}
.modal-char-header{display:flex;align-items:center;gap:1.2rem;margin-bottom:1.5rem;flex-wrap:wrap}
.modal-char-portrait{width:80px;height:80px;border-radius:12px;overflow:hidden;border:2px solid var(--border);flex-shrink:0}
.modal-char-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 15%}
.modal-char-name{font-family:'Cinzel Decorative',serif;font-size:1.5rem;font-weight:700;color:var(--white)}
.modal-char-element{display:inline-block;margin-top:.3rem;padding:.2rem .6rem;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--cc,var(--border));color:var(--cc,var(--cyan))}
.build-section-title{font-size:.68rem;text-transform:uppercase;letter-spacing:.3em;color:var(--gold);font-weight:700;margin:1.2rem 0 .7rem}

.build-img-wrap{border-radius:12px;overflow:hidden;border:1px solid var(--border);background:rgba(8,12,24,.5);position:relative;margin-bottom:1rem}
.build-img-wrap img{width:100%;display:block}
.build-img-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;padding:3rem 2rem;color:var(--muted);font-size:.85rem;text-align:center;border-radius:12px;border:2px dashed var(--border);background:rgba(56,184,208,.03)}
.build-img-placeholder svg{width:40px;height:40px;opacity:.4}
.build-img-placeholder a{color:var(--cyan);font-weight:600;font-size:.78rem}

.build-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,140px),1fr));gap:.6rem;margin-bottom:1rem}
.bstat{background:rgba(56,184,208,.06);border:1px solid rgba(56,184,208,.15);border-radius:8px;padding:.6rem .8rem;display:flex;flex-direction:column;gap:.2rem}
.bstat-lbl{font-size:.6rem;text-transform:uppercase;letter-spacing:.15em;color:var(--muted);font-weight:600}
.bstat-val{font-family:'Orbitron',monospace;font-size:.9rem;font-weight:700;color:var(--white)}

.reviews-section{max-width:900px;margin:0 auto;padding:clamp(3rem,8vh,5rem) clamp(1rem,4vw,2rem)}
.review-btn-wrap{text-align:center;margin-bottom:2.5rem}
.review-btn{display:inline-flex;align-items:center;gap:.6rem;background:rgba(56,184,208,.1);border:1px solid rgba(56,184,208,.4);border-radius:8px;padding:.75rem 1.8rem;color:var(--cyan);font-family:'Raleway',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .3s,transform .3s var(--ease-back),box-shadow .3s}
.review-btn:hover{background:rgba(56,184,208,.2);transform:translateY(-3px);box-shadow:0 8px 25px rgba(56,184,208,.2)}
.review-form-wrap{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;margin-bottom:2rem;display:none;backdrop-filter:blur(12px);animation:panel-in .4s var(--ease-expo)}
.review-form-wrap.open{display:block}
@keyframes panel-in{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.review-form-title{font-family:'Cinzel Decorative',serif;font-size:1rem;color:var(--white);margin-bottom:1.2rem;text-align:center}
.rf-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold);font-weight:700;margin-bottom:.4rem;display:block}
.rf-input,.rf-textarea{width:100%;background:rgba(56,184,208,.05);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;color:var(--white);font-family:'Raleway',sans-serif;font-size:.88rem;outline:none;transition:border-color .25s,box-shadow .25s;resize:none}
.rf-input:focus,.rf-textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(56,184,208,.1)}
.rf-textarea{min-height:110px;line-height:1.6}
.rf-group{margin-bottom:1rem}
.rf-row{display:flex;gap:.75rem;flex-wrap:wrap}
.rf-row .rf-group{flex:1;min-width:180px}
.rf-submit{width:100%;padding:.8rem;background:rgba(56,184,208,.15);border:1px solid rgba(56,184,208,.5);border-radius:8px;color:var(--cyan);font-family:'Raleway',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:background .3s,transform .3s var(--ease-back);margin-top:.5rem}
.rf-submit:hover{background:rgba(56,184,208,.28);transform:translateY(-2px)}
.rf-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}
.rf-note{font-size:.7rem;color:var(--muted);text-align:center;margin-top:.5rem}
.rf-msg{text-align:center;padding:.6rem 1rem;border-radius:6px;font-size:.82rem;font-weight:600;margin-top:.75rem;display:none}
.rf-msg.ok{display:block;background:rgba(61,220,132,.1);border:1px solid rgba(61,220,132,.4);color:#3ddc84}
.rf-msg.err{display:block;background:rgba(255,60,60,.1);border:1px solid rgba(255,60,60,.3);color:#ff7070}
.reviews-list{display:flex;flex-direction:column;gap:1rem}
.review-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.3rem;backdrop-filter:blur(10px);animation:panel-in .4s var(--ease-expo)}
.review-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;flex-wrap:wrap;gap:.4rem}
.review-pseudo{font-weight:700;font-size:.88rem;color:var(--cyan)}
.review-date{font-size:.67rem;color:var(--muted)}
.review-text{font-size:.85rem;line-height:1.75;color:rgba(224,240,255,.78)}
.reviews-empty{text-align:center;color:var(--muted);font-size:.85rem;padding:2rem;border:1px dashed var(--border);border-radius:10px}
