:root{
  --ink:#050b16;
  --night:#060d1c;
  --sky:#0e1f3a;
  --mist:#1b2b45;
  --cloud:#dce6ff;
  --text:#e8f1ff;
  --muted:#9fb4d8;
  --gold:#d9ba73;
  --crystal:#66c7ff;
  --rose:#e594b9;
  --line:#20324f;
  --panel:rgba(10,20,38,.85);
  --panel-light:rgba(24,39,66,.92);
  --shadow:0 20px 50px -35px rgba(4,8,20,.9);
  --radius:14px;
  --radius-lg:18px;
  --mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  --serif:"Playfair Display","Times New Roman",serif;
  --sans:"Source Sans 3","Segoe UI",Roboto,"Noto Sans","Helvetica Neue",Arial,sans-serif;
}

@font-face{
  font-family: "Jupiter Pro";
  src:
    url("../fonts/JupiterPro-Bold.woff2") format("woff2"),
    url("../fonts/Jupiter Pro Bold.otf") format("opentype");
  font-weight:700;
  font-style:normal;
  font-display:swap;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%;}
body{
  font-family:var(--sans);
  line-height:1.5;
  color:var(--text);
  background:radial-gradient(circle at 20% 20%, rgba(80,132,255,.25), transparent 45%),
             radial-gradient(circle at 80% 0%, rgba(255,255,255,.08), transparent 50%),
             linear-gradient(145deg, var(--ink), var(--sky));
 background-repeat:no-repeat,no-repeat,no-repeat;
  background-size:160% 160%,140% 140%,cover;
  background-attachment:fixed,fixed,fixed;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.ffxiv-canvas{position:relative;overflow-x:hidden;}
.starlight{
  position:fixed;
  inset:0;
  pointer-events:none;
  background-repeat:repeat;
  mix-blend-mode:screen;
  opacity:.25;
  z-index:0;
}
.starlight-one{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Ccircle cx='8' cy='8' r='1' fill='white'/%3E%3Ccircle cx='42' cy='128' r='1' fill='white'/%3E%3Ccircle cx='90' cy='54' r='1' fill='white'/%3E%3Ccircle cx='150' cy='140' r='1' fill='white'/%3E%3C/svg%3E");background-size:160px 160px;animation:drift-pattern-sm 38s linear infinite;}
.starlight-two{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220' viewBox='0 0 220 220'%3E%3Ccircle cx='24' cy='48' r='1' fill='%23d6ffff'/%3E%3Ccircle cx='160' cy='140' r='1' fill='%23d6ffff'/%3E%3Ccircle cx='40' cy='200' r='1' fill='%23d6ffff'/%3E%3C/svg%3E");background-size:220px 220px;animation:drift-pattern-lg 60s linear infinite reverse;opacity:.35;}
.starlight-three{
  background:radial-gradient(circle, rgba(102,199,255,.18), transparent 45%) 10% 20%/320px 320px,
             radial-gradient(circle, rgba(217,186,115,.2), transparent 35%) 80% 70%/400px 400px;
  animation:pulse 12s ease-in-out infinite;
  opacity:.4;
}

@keyframes drift{0%{transform:translate3d(0,0,0);}100%{transform:translate3d(-160px,-80px,0);}}
@keyframes drift-pattern-sm{0%{background-position:0 0;}100%{background-position:-160px -80px;}}
@keyframes drift-pattern-lg{0%{background-position:0 0;}100%{background-position:-220px -110px;}}
@keyframes pulse{0%,100%{opacity:.25;}50%{opacity:.45;}}

.container{max-width:1100px;margin:0 auto;padding:24px;position:relative;z-index:1;}

.page-shell{position:relative;z-index:1;padding-bottom:80px;flex:1;display:flex;flex-direction:column;}
.page{padding:36px 0 40px;flex:1;}

.ls-header{
  position:relative;
  z-index:2;
  background:linear-gradient(135deg, rgba(6,18,40,.96), rgba(8,12,24,.92));
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow:0 30px 80px -60px #000;
}
.ls-header .container{
  display:flex;align-items:center;justify-content:space-between;gap:32px;padding:26px 24px;
}
.brand{color:#fff;text-decoration:none;display:flex;align-items:center;gap:16px;}
.logo{
  width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  box-shadow:0 0 20px rgba(102,199,255,.4), inset 0 0 15px rgba(102,199,255,.4);
  font-size:26px;font-weight:700;color:#04122a;
}
.brand-stack{display:flex;flex-direction:column;line-height:1.2;}
.wordmark{font-size:1.8rem;letter-spacing:.08em;text-transform:uppercase;}
.tagline{font-size:.88rem;color:rgba(232,241,255,.75);font-variant:small-caps;letter-spacing:.18em;}

.primary-nav a{
  color:var(--cloud);
  text-decoration:none;
  font-weight:600;
  letter-spacing:.04em;
  margin-left:18px;
  padding-bottom:4px;
  border-bottom:2px solid transparent;
  transition:border-color .2s ease,color .2s ease;
}
.primary-nav a:hover,.primary-nav a:focus{color:#fff;border-bottom-color:var(--gold);}
.primary-nav .sign-in{color:var(--gold);}

.breadcrumb{font-size:.9rem;color:var(--muted);margin:0 0 18px;text-transform:uppercase;letter-spacing:.18em;}
.breadcrumb a{color:var(--cloud);text-decoration:none;}

.module{
  background:var(--panel);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  overflow:hidden;
  backdrop-filter:blur(22px);
}
.module.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;background:transparent;border:0;box-shadow:none;}
@media (max-width:900px){.module.two-col{grid-template-columns:1fr;}}
.module-head{
  padding:18px 24px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:linear-gradient(120deg, rgba(255,255,255,.08), rgba(102,199,255,.15));
}
.module-head h1,.module-head h2{margin:0;font-family:var(--serif);font-size:1.4rem;letter-spacing:.04em;}
.module-body{padding:24px 24px 28px;}
.lead{color:var(--muted);}

.actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:14px;}
.hint{color:var(--muted);font-size:.9rem;}

.btn{
  --bg:rgba(255,255,255,.1);
  --fg:var(--cloud);
  --bd:rgba(255,255,255,.16);
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 18px;border-radius:999px;border:1px solid var(--bd);
  background:var(--bg);
  color:var(--fg);
  text-decoration:none;font-weight:600;letter-spacing:.04em;
  cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease,background .2s ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px -16px rgba(0,0,0,.6);} 
.btn:active{transform:translateY(1px);}
.btn-primary{
  --bg:linear-gradient(120deg,#7dd5ff,#4a7bff);
  --fg:#04122a;
  --bd:rgba(255,255,255,.35);
  color:var(--fg);
  box-shadow:0 20px 40px -24px #66c7ff;
}

.flash{
  background:var(--panel-light);
  border:1px solid rgba(255,255,255,.1);
  border-left:4px solid var(--crystal);
  border-radius:var(--radius);
  padding:16px 20px;
  margin:18px 0;
  box-shadow:0 12px 26px -24px rgba(0,0,0,.6);
}
.flash .flash-title{font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;font-size:.85rem;}
.flash.error{border-left-color:#ff7a8a;}
.flash.warning{border-left-color:var(--gold);}
.flash.info{border-left-color:var(--crystal);}

.profile-row{display:grid;grid-template-columns:56px 1fr auto;gap:12px;align-items:center;padding:12px 0;border-top:1px dashed rgba(255,255,255,.12);border-bottom:1px dashed rgba(255,255,255,.12);margin:12px 0;}
.avatar{width:56px;height:56px;border-radius:8px;display:grid;place-items:center;font-weight:800;color:#04122a;background:linear-gradient(135deg,#8fd5ff,#4a7bff);border:1px solid rgba(255,255,255,.4);box-shadow:0 14px 30px -20px rgba(0,0,0,.8);}
.avatar.xl{width:90px;height:90px;border-radius:14px;font-size:1.8rem;}

.info .eyebrow{font-size:.75rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;}
.info .title{font-size:1.6rem;font-weight:700;font-family:var(--serif);} 
.subtle{color:var(--muted);} 
.pk{color:var(--muted);} 

.profile-card{display:grid;grid-template-columns:180px 1fr;gap:24px;align-items:start;}
@media (max-width:760px){.profile-card{grid-template-columns:1fr;}}
.portrait-wrap{width:180px;}
.portrait{width:180px;height:180px;object-fit:cover;border-radius:var(--radius);border:1px solid rgba(255,255,255,.18);box-shadow:0 20px 40px -30px #000;background:#0b1a2d;display:block;}
.portrait.placeholder{display:grid;place-items:center;font-weight:800;font-size:42px;color:#04122a;background:linear-gradient(135deg,#8fd5ff,#4a7bff);border:1px solid rgba(255,255,255,.5);}

.profile-body{display:grid;grid-template-columns:120px 1fr;gap:18px;align-items:start;}

.kv{margin:12px 0;}
.kv dt{font-size:.8rem;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;}
.kv dd{margin:4px 0 0;font-size:1rem;}
.uid{display:inline-block;padding:6px 12px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:rgba(255,255,255,.05);}
.mono{font-family:var(--mono);}

.ls-footer{
  background:rgba(5,11,22,.8);
  border-top:1px solid rgba(255,255,255,.08);
  position:relative;
  z-index:1;
}
.ls-footer .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;padding:30px 24px;}
.footer-nav a{color:var(--muted);text-decoration:none;margin-right:18px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem;}
.footer-nav a:hover{text-decoration:underline;color:#fff;}

/* Character picker */
.filter-row{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap;}
.search{flex:1;padding:10px 12px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:rgba(4,9,20,.65);color:var(--text);font-size:1rem;}
.search::placeholder{color:rgba(255,255,255,.4);}

.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
.char-card{display:grid;grid-template-columns:200px 1fr;gap:14px;align-items:center;padding:14px;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);background:rgba(10,22,40,.8);box-shadow:0 18px 36px -28px rgba(0,0,0,.8);cursor:pointer;position:relative;transition:border-color .12s ease,box-shadow .12s ease,transform .1s ease;}
.char-card:hover{transform:translateY(-2px);box-shadow:0 24px 36px -30px rgba(102,199,255,.4);}
.char-card.selected{border-color:var(--crystal);box-shadow:0 30px 40px -32px rgba(102,199,255,.5);}
.char-card input[type="radio"]{position:absolute;inset:0;opacity:0;pointer-events:none;}
.char-info .char-name{font-weight:700;font-size:1.05rem;letter-spacing:.02em;}
.char-info .char-world{margin-top:4px;color:var(--muted);}

.empty{color:var(--muted);padding:12px;border:1px dashed rgba(255,255,255,.25);border-radius:var(--radius);background:rgba(10,22,40,.8);}

/* Alerts */
.infobox{position:relative;padding:12px 16px;border:1px solid rgba(255,255,255,.12);border-left:4px solid var(--crystal);border-radius:var(--radius);background:rgba(10,24,42,.85);color:var(--text);margin:12px 0;box-shadow:0 16px 34px -28px rgba(0,0,0,.8);}
.infobox .infobox-title{font-weight:700;margin:0 0 4px;font-size:1rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.infobox .infobox-body{margin:0;color:var(--cloud);}
.infobox .close{position:absolute;top:8px;right:12px;border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:18px;}
.infobox .close:hover{color:#fff;}
.infobox.info{border-left-color:var(--crystal);} 
.infobox.success{border-left-color:#54e2b2;} 
.infobox.warning{border-left-color:var(--gold);} 
.infobox.danger{border-left-color:#ff8f9d;} 
.infobox.primary{border-left-color:var(--crystal);} 
.infobox.compact{padding:10px 12px;border-radius:10px;}

.alias-form{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;}
.alias-input,.hex-input{padding:10px 14px;border:1px solid rgba(255,255,255,.25);border-radius:10px;background:rgba(4,9,20,.65);color:var(--text);font-size:1rem;min-width:220px;}
.label{display:block;font-size:.75rem;color:var(--muted);margin-bottom:6px;letter-spacing:.12em;text-transform:uppercase;}
.color-row{display:flex;gap:12px;align-items:center;}
.color-row input[type="color"]{width:48px;height:48px;border:1px solid rgba(255,255,255,.4);border-radius:14px;background:transparent;padding:2px;}

.claim-box{margin-top:12px;}
.claim-label{display:block;margin-bottom:12px;font-size:.9rem;color:var(--muted);}
.claim-label input{width:100%;max-width:420px;padding:10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:rgba(4,9,20,.65);color:var(--text);font-size:1rem;}

.secret{filter:blur(8px);transition:filter .15s ease;user-select:none;}
.secret.revealed{filter:none;user-select:text;}
.masked::selection{background:transparent;}

.gold-rule{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--gold),transparent);}

@media (max-width:640px){
  .ls-header .container{flex-direction:column;align-items:flex-start;}
  .primary-nav{width:100%;display:flex;gap:12px;}
  .actions{flex-direction:column;align-items:flex-start;}
  .container{padding:20px;}
}

a {
color: var(--muted);
}