:root{
  --public-shell-top: rgba(56,37,40,0.96);
  --public-shell-bottom: rgba(19,11,18,0.988);
  --public-inset-top: rgba(16,11,16,0.97);
  --public-inset-bottom: rgba(7,4,11,0.996);
  --public-border: rgba(146,114,106,0.42);
  --public-border-strong: rgba(193,154,131,0.50);
  --public-line: rgba(164,129,111,0.36);
  --public-text: #f4ece7;
  --public-muted: rgba(235,221,214,0.72);
  --public-accent: #8ec2ff;
  --public-accent-soft: rgba(142,194,255,0.22);
  --public-shadow: 0 18px 42px rgba(0,0,0,0.38);
  --public-corner-tl: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cpath d='M30 3H9L3 9v21' fill='none' stroke='%238a6a63' stroke-width='1.3' stroke-linecap='square'/%3E%3Cpath d='M27.5 5.5H9.9L5.5 9.9v16.8' fill='none' stroke='%2352383c' stroke-width='1'/%3E%3C/svg%3E");
  --public-corner-br: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='34' height='34' viewBox='0 0 34 34'%3E%3Cg transform='translate(34 34) rotate(180)'%3E%3Cpath d='M30 3H9L3 9v21' fill='none' stroke='%238a6a63' stroke-width='1.3' stroke-linecap='square'/%3E%3Cpath d='M27.5 5.5H9.9L5.5 9.9v16.8' fill='none' stroke='%2352383c' stroke-width='1'/%3E%3C/g%3E%3C/svg%3E");
  --public-divider: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='14' viewBox='0 0 240 14'%3E%3Cpath d='M0 7H94l8-5h36l8 5h94' fill='none' stroke='%23886d65' stroke-width='1.15'/%3E%3Cpath d='M100 7h40' fill='none' stroke='%23b58f74' stroke-width='0.8' opacity='0.55'/%3E%3Cpath d='M120 1l6 6-6 6-6-6z' fill='%238ec2ff' stroke='%23d6ecff' stroke-width='1'/%3E%3C/svg%3E");
}

body.public-page{
  min-height:100vh;
  color:var(--public-text);
  background:
    linear-gradient(180deg, rgba(5,8,13,0.88) 0%, rgba(7,6,10,0.95) 100%),
    #090d12;
}
body.public-page::before,
body.public-page::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
}
body.public-page::before{
  z-index:0;
  background:
    linear-gradient(180deg, rgba(7,10,16,0.28), rgba(7,5,10,0.68)),
    url("../img/ui/public/login_bg.jpg") center center / cover no-repeat;
  filter:saturate(1.02) brightness(0.72);
}
body.public-page::after{
  z-index:0;
  background:
    radial-gradient(circle at 16% 84%, rgba(84,155,255,0.16) 0%, rgba(84,155,255,0.04) 18%, rgba(0,0,0,0) 42%),
    radial-gradient(circle at 84% 18%, rgba(255,167,94,0.20) 0%, rgba(255,167,94,0.05) 18%, rgba(0,0,0,0) 44%),
    linear-gradient(180deg, rgba(4,7,12,0.12), rgba(4,4,7,0.34));
}

body.public-page a{color:var(--public-text);}
body.public-page a:hover{text-decoration:none;}
body.public-page .muted{color:var(--public-muted);}

.public-shell{
  position:relative;
  z-index:1;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  padding:28px 18px 24px;
}

.public-frame{
  position:relative;
  width:min(1160px, 100%);
  margin-inline:auto;
  padding:24px;
  border:1px solid var(--public-border);
  background:
    linear-gradient(180deg, rgba(17,19,31,0.78) 0%, rgba(10,8,14,0.92) 100%),
    radial-gradient(circle at 50% 10%, rgba(255,184,115,0.08) 0%, rgba(255,184,115,0.02) 24%, rgba(0,0,0,0) 58%),
    rgba(9,10,18,0.84);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), var(--public-shadow);
  backdrop-filter:blur(6px);
  clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);
  overflow:hidden;
}
.public-frame::before,
.public-frame::after,
.public-panel::before,
.public-panel::after,
.public-panel-inset::before,
.public-panel-inset::after{
  content:'';
  position:absolute;
  width:44px;
  height:44px;
  opacity:.98;
  pointer-events:none;
}
.public-frame::before,
.public-panel::before,
.public-panel-inset::before{left:2px;top:2px;background:var(--public-corner-tl) center/44px 44px no-repeat;}
.public-frame::after,
.public-panel::after,
.public-panel-inset::after{right:2px;bottom:2px;background:var(--public-corner-br) center/44px 44px no-repeat;}
.public-frame > *{position:relative;z-index:1;}

.public-frame-beta{
  position:absolute;
  top:18px;
  right:20px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:92px;
  min-height:38px;
  padding:8px 16px;
  border:1px solid rgba(255,181,181,0.42);
  background:
    linear-gradient(180deg, rgba(176,54,66,0.98) 0%, rgba(110,28,40,0.98) 54%, rgba(72,15,28,0.995) 100%),
    radial-gradient(circle at 50% 18%, rgba(255,255,255,0.16), rgba(255,255,255,0) 42%);
  color:#fff1f2;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  text-shadow:0 1px 0 rgba(68,8,16,0.56), 0 0 14px rgba(255,171,171,0.20);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.16), inset 0 -8px 18px rgba(40,6,14,0.24), 0 0 0 1px rgba(255,95,95,0.12), 0 14px 30px rgba(72,8,18,0.44), 0 0 18px rgba(184,36,52,0.22);
  transform:rotate(8deg);
}

.public-hero{
  display:grid;
  grid-template-columns:160px minmax(0,1fr);
  gap:24px;
  align-items:stretch;
}
.public-logo-wrap{
  position:relative;
  min-height:190px;
  height:auto;
  align-self:stretch;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(188,151,129,0.30);
  background:linear-gradient(180deg, rgba(61,40,44,0.82), rgba(19,11,18,0.94));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 14px 28px rgba(0,0,0,0.28);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
}
.public-logo-wrap::after{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 50%, rgba(142,194,255,0.12), rgba(0,0,0,0) 62%);
}
.public-logo{max-width:128px;width:100%;height:auto;filter:drop-shadow(0 0 14px rgba(120,190,255,0.30)) drop-shadow(0 0 24px rgba(255,182,107,0.16));}
.public-hero-copy{min-width:0;}
.public-page-index .public-hero-copy,
.public-page-faq .public-hero-copy,
.public-page-login .public-hero-copy,
.public-page-register .public-hero-copy,
.public-page-contact .public-hero-copy,
.public-page-lobby .public-hero-copy,
.public-page-intro .public-hero-copy,
.public-page-world_intro .public-hero-copy{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:8px;
  min-height:190px;
  padding:22px 26px;
  border:1px solid var(--public-border);
  background:linear-gradient(180deg, var(--public-shell-top), var(--public-shell-bottom));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 14px 32px rgba(0,0,0,0.24);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
  overflow:hidden;
}
.public-page-index .public-hero-copy::before,
.public-page-faq .public-hero-copy::before,
.public-page-login .public-hero-copy::before,
.public-page-register .public-hero-copy::before,
.public-page-contact .public-hero-copy::before,
.public-page-lobby .public-hero-copy::before,
.public-page-intro .public-hero-copy::before,
.public-page-world_intro .public-hero-copy::before,
.public-page-index .public-hero-copy::after,
.public-page-faq .public-hero-copy::after,
.public-page-login .public-hero-copy::after,
.public-page-register .public-hero-copy::after,
.public-page-contact .public-hero-copy::after,
.public-page-lobby .public-hero-copy::after,
.public-page-intro .public-hero-copy::after,
.public-page-world_intro .public-hero-copy::after{
  content:'';
  position:absolute;
  width:44px;
  height:44px;
  opacity:.98;
  pointer-events:none;
}
.public-page-index .public-hero-copy::before,
.public-page-faq .public-hero-copy::before,
.public-page-login .public-hero-copy::before,
.public-page-register .public-hero-copy::before,
.public-page-contact .public-hero-copy::before,
.public-page-lobby .public-hero-copy::before,
.public-page-intro .public-hero-copy::before{
  left:2px;
  top:2px;
  background:var(--public-corner-tl) center/44px 44px no-repeat;
}
.public-page-index .public-hero-copy::after,
.public-page-faq .public-hero-copy::after,
.public-page-login .public-hero-copy::after,
.public-page-register .public-hero-copy::after,
.public-page-contact .public-hero-copy::after,
.public-page-lobby .public-hero-copy::after,
.public-page-intro .public-hero-copy::after{
  right:2px;
  bottom:2px;
  background:var(--public-corner-br) center/44px 44px no-repeat;
}
.public-page-index .public-hero-copy > *,
.public-page-faq .public-hero-copy > *,
.public-page-login .public-hero-copy > *,
.public-page-register .public-hero-copy > *,
.public-page-contact .public-hero-copy > *,
.public-page-lobby .public-hero-copy > *,
.public-page-intro .public-hero-copy > *,
.public-page-world_intro .public-hero-copy > *{position:relative;z-index:1;}
.public-page-index .public-hero-copy .public-heading,
.public-page-faq .public-hero-copy .public-heading,
.public-page-login .public-hero-copy .public-heading,
.public-page-register .public-hero-copy .public-heading,
.public-page-contact .public-hero-copy .public-heading,
.public-page-lobby .public-hero-copy .public-heading,
.public-page-intro .public-hero-copy .public-heading,
.public-page-world_intro .public-hero-copy .public-heading{margin:0;}
.public-page-index .public-hero-copy .public-intro,
.public-page-faq .public-hero-copy .public-intro,
.public-page-login .public-hero-copy .public-intro,
.public-page-register .public-hero-copy .public-intro,
.public-page-contact .public-hero-copy .public-intro,
.public-page-lobby .public-hero-copy .public-intro,
.public-page-intro .public-hero-copy .public-intro,
.public-page-world_intro .public-hero-copy .public-intro{max-width:none;}

.public-kicker,
.public-eyebrow{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  padding:4px 10px;
  border:1px solid rgba(188,151,129,0.30);
  background:linear-gradient(180deg, rgba(78,50,50,.82), rgba(30,17,25,.86));
  color:var(--public-text);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-heading{
  margin:10px 0 8px;
  font-size:clamp(34px, 4vw, 54px);
  line-height:1;
  font-weight:900;
  letter-spacing:.02em;
  color:var(--public-text);
}
.public-intro{max-width:760px;margin:0;color:var(--public-muted);font-size:16px;line-height:1.58;}
.public-nav{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px;}
.public-nav-form{display:inline-flex;margin:0;}
.public-nav a,
.public-nav .public-nav-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:8px 14px;
  border:1px solid rgba(184,146,123,0.24);
  background:linear-gradient(180deg, rgba(71,47,48,.78), rgba(28,17,24,.90));
  color:var(--public-text);
  font-size:13px;
  cursor:pointer;
  appearance:none;
}
.public-nav .public-nav-button{
  font:inherit;
  text-decoration:none;
  font-weight:800;
  letter-spacing:.02em;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  transition:background .14s ease,border-color .14s ease,transform .14s ease,box-shadow .14s ease;
}
.public-nav a:hover,
.public-nav .public-nav-button:hover{border-color:rgba(206,168,143,0.40);background:linear-gradient(180deg, rgba(87,58,59,.90), rgba(34,20,28,.98));transform:translateY(-1px);}
.public-nav a.is-active,
.public-nav .public-nav-button.is-active{border-color:rgba(142,194,255,0.34);box-shadow:inset 0 0 0 1px rgba(142,194,255,0.10), 0 8px 18px rgba(0,0,0,.20);}
.public-divider{position:relative;height:18px;margin:16px 0 20px;}
.public-divider::after{content:'';position:absolute;left:50%;top:0;transform:translateX(-50%);width:min(520px, 82%);height:18px;background:var(--public-divider) center/100% 14px no-repeat;opacity:.98;}
.public-divider--frame-end{margin-bottom:0;}
.public-content{display:flex;flex-direction:column;gap:18px;}

.public-grid{display:grid;gap:18px;grid-template-columns:minmax(0,1fr) minmax(280px, 340px);align-items:start;}
.public-grid--single{grid-template-columns:minmax(0,1fr);}
.public-stack{display:flex;flex-direction:column;gap:18px;}
.public-panel,
.public-panel-inset{
  position:relative;
  overflow:hidden;
}
.public-panel{
  padding:18px;
  border:1px solid var(--public-border);
  background:linear-gradient(180deg, var(--public-shell-top), var(--public-shell-bottom));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 14px 32px rgba(0,0,0,0.28);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
}
.public-panel-inset{
  padding:16px;
  border:1px solid rgba(164,129,111,0.18);
  background:linear-gradient(180deg, var(--public-inset-top), var(--public-inset-bottom));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.015);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}
.public-panel-title{
  position:relative;
  margin:0 0 16px;
  padding:0 0 18px 12px;
}
.public-panel-title::after{content:'';position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:min(420px, 88%);height:14px;background:var(--public-divider) center/100% 14px no-repeat;opacity:.98;}
.public-panel-title h2{margin:10px 0 0;font-size:25px;line-height:1.12;color:var(--public-text);}
.public-panel-title p{margin:8px 0 0;color:var(--public-muted);line-height:1.55;}

body.public-page .alert{
  border-radius:0;
  border:1px solid rgba(184,146,123,0.26);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  background:linear-gradient(180deg, rgba(53,34,40,.92), rgba(18,11,17,.98));
  color:var(--public-text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.02);
}
body.public-page .alert.ok{border-color:rgba(126,231,135,.34);box-shadow:inset 0 0 0 1px rgba(126,231,135,.08), 0 10px 20px rgba(0,0,0,.18);}
body.public-page .alert.err{border-color:rgba(224,108,117,.34);box-shadow:inset 0 0 0 1px rgba(224,108,117,.08), 0 10px 20px rgba(0,0,0,.18);}

body.public-page .label{display:block;margin:0 0 8px;color:rgba(235,221,214,0.86);font-weight:800;letter-spacing:.02em;}
body.public-page .input,
body.public-page textarea.input{
  width:100%;
  min-height:46px;
  padding:12px 14px;
  border-radius:0;
  border:1px solid rgba(164,129,111,0.18);
  background:linear-gradient(180deg, rgba(35,23,28,.96), rgba(17,10,17,.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.015);
  color:var(--public-text);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
body.public-page .input:focus,
body.public-page textarea.input:focus{
  outline:none;
  border-color:rgba(142,194,255,0.34);
  box-shadow:inset 0 0 0 1px rgba(142,194,255,0.10), 0 0 0 2px rgba(142,194,255,0.07);
}
body.public-page textarea.input{min-height:210px;resize:vertical;line-height:1.45;}
body.public-page .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 16px;
  border:1px solid rgba(184,146,123,0.26);
  border-radius:0;
  background:linear-gradient(180deg, rgba(71,47,48,.92), rgba(28,17,24,.96));
  color:var(--public-text);
  font-weight:800;
  text-decoration:none;
  cursor:pointer;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03), 0 6px 14px rgba(0,0,0,.18);
  transition:background .14s ease,border-color .14s ease,transform .14s ease,box-shadow .14s ease;
}
body.public-page .btn:hover{border-color:rgba(206,168,143,0.40);background:linear-gradient(180deg, rgba(87,58,59,.96), rgba(34,20,28,.99));transform:translateY(-1px);}
body.public-page .btn.primary{border-color:rgba(142,194,255,0.34);box-shadow:inset 0 0 0 1px rgba(142,194,255,0.10), 0 8px 18px rgba(0,0,0,.22);}

.public-form{display:flex;flex-direction:column;gap:14px;}
.public-form-actions{display:flex;gap:10px;justify-content:flex-start;flex-wrap:wrap;margin-top:4px;}
.public-form-actions--create-split{justify-content:space-between;align-items:center;gap:12px;margin-top:6px;}
.public-form-actions--create-split .btn{min-width:156px;}
.public-form-actions--create-split .btn.primary{margin-left:auto;}
.public-info-list{display:flex;flex-direction:column;gap:12px;}
.public-info-item{padding:12px 14px;border:1px solid rgba(184,146,123,0.16);background:rgba(255,255,255,0.025);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);}
.public-info-item strong{display:block;margin-bottom:4px;color:var(--public-text);}
.public-note{margin-top:12px;color:var(--public-muted);font-size:13px;line-height:1.5;}
.public-copy-block{display:flex;flex-direction:column;gap:10px;}
.public-copy-block h3{margin:0;font-size:22px;line-height:1.12;color:var(--public-text);}
.public-copy-block p{margin:0;color:var(--public-muted);line-height:1.65;}
.public-index-story-grid{margin-top:18px;}
.public-buttons{display:grid;gap:12px;grid-template-columns:repeat(3, minmax(0,1fr));}
.public-buttons .btn{width:100%;}
.public-buttons--dual{grid-template-columns:repeat(2, minmax(0,1fr));}
.public-feature-row{display:grid;gap:14px;grid-template-columns:repeat(3, minmax(0,1fr));}
.public-feature{padding:16px;min-height:100%;}
.public-feature strong{display:block;margin-bottom:6px;font-size:14px;color:var(--public-text);}
.public-inline-note{margin-top:14px;color:var(--public-muted);font-size:13px;line-height:1.5;text-align:center;}
.public-status-grid{display:grid;gap:10px;grid-template-columns:repeat(3, minmax(0,1fr));margin-bottom:12px;}
.public-stat{padding:12px 14px;border:1px solid rgba(184,146,123,0.16);background:rgba(255,255,255,0.025);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);}
.public-stat span{display:block;font-size:11px;letter-spacing:.10em;text-transform:uppercase;color:var(--public-muted);margin-bottom:6px;}
.public-stat strong{display:block;font-size:22px;line-height:1;color:var(--public-text);}
.public-character-name{margin:0 0 6px;font-size:28px;line-height:1.08;color:var(--public-text);}
.public-character-sub{margin:0;color:var(--public-muted);}
.public-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;}
.public-badge{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:8px 12px;border:1px solid rgba(184,146,123,0.18);background:rgba(255,255,255,0.03);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);}
.public-badge-dot{width:10px;height:10px;border-radius:50%;display:inline-block;box-shadow:0 0 10px currentColor;}
.public-badge-dot.st-on{background:#1fe27a;color:#1fe27a;}
.public-badge-dot.st-afk{background:#ffd54a;color:#ffd54a;}
.public-badge-dot.st-dnd{background:#ff6a6a;color:#ff6a6a;}
.public-badge-dot.st-off{background:#9aa4b2;color:#9aa4b2;}
.public-highlight{display:flex;flex-direction:column;gap:14px;justify-content:space-between;min-height:100%;}


.public-lobby-grid{display:grid;gap:18px;grid-template-columns:minmax(0,1fr);align-items:start;}
.public-lobby-panel{padding-bottom:20px;}
.public-panel-title--compact{margin-bottom:18px;}
.public-panel-title--compact::after{width:min(320px, 72%);}
.public-char-slot-list{display:flex;flex-direction:column;gap:16px;}
.public-char-slot-row,
.public-char-add-row{
  --public-class-accent:#d4a96b;
  --public-class-rgb:212 169 107;
  display:grid;
  gap:16px;
  grid-template-columns:minmax(0,1fr) 168px;
  align-items:stretch;
}
.public-char-slot-card,
.public-char-add-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(184,146,123,0.22);
  background:
    radial-gradient(circle at 18% 50%, rgb(var(--public-class-rgb) / 0.10), rgba(0,0,0,0) 26%),
    radial-gradient(circle at 82% 18%, rgba(255,194,129,0.08), rgba(0,0,0,0) 32%),
    linear-gradient(180deg, rgba(35,23,28,0.95), rgba(11,7,13,0.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 16px 34px rgba(0,0,0,0.24);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
}
.public-char-slot-card::before,
.public-char-add-card::before,
.public-char-slot-card::after,
.public-char-add-card::after{
  content:'';
  position:absolute;
  pointer-events:none;
}
.public-char-slot-card::before,
.public-char-add-card::before{
  left:0;
  top:0;
  bottom:0;
  width:4px;
  background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.92), rgb(var(--public-class-rgb) / 0.16));
}
.public-char-slot-card::after,
.public-char-add-card::after{
  inset:0;
  background:linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0) 46%, rgba(255,194,129,0.06) 100%);
}
.public-char-slot-card{display:grid;gap:18px;grid-template-columns:168px minmax(0,1fr);padding:16px;}
.public-char-slot-row.is-active .public-char-slot-card{border-color:rgb(var(--public-class-rgb) / 0.30);box-shadow:inset 0 0 0 1px rgb(var(--public-class-rgb) / 0.08), 0 18px 36px rgba(0,0,0,0.26);}
.public-char-slot-row:hover .public-char-slot-card{border-color:rgba(206,168,143,0.30);}
.public-char-slot-card > *,
.public-char-add-card > *{position:relative;z-index:1;}
.public-char-slot-visual{display:flex;flex-direction:column;gap:10px;min-width:0;}
.public-char-slot-stage{
  position:relative;
  min-height:196px;
  display:grid;
  place-items:center;
  padding:14px 12px;
  border:1px solid rgba(184,146,123,0.18);
  background:
    radial-gradient(circle at 50% 74%, rgb(var(--public-class-rgb) / 0.18), rgba(0,0,0,0) 34%),
    linear-gradient(180deg, rgba(38,25,30,0.94), rgba(10,7,13,0.99));
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  overflow:hidden;
}
.public-char-slot-stage::after{
  content:'';
  position:absolute;
  inset:0;
  background:var(--public-lobby-stage-bg, none) center bottom / cover no-repeat;
  opacity:.20;
  mix-blend-mode:screen;
}
.public-char-slot-stage::before{
  content:'';
  position:absolute;
  left:50%;
  bottom:10px;
  transform:translateX(-50%);
  width:72%;
  height:20px;
  background:radial-gradient(circle at 50% 50%, rgb(var(--public-class-rgb) / 0.28) 0%, rgba(0,0,0,0) 70%);
  filter:blur(9px);
  opacity:.88;
}
.public-char-slot-stage img{
  position:relative;
  z-index:1;
  display:block;
  margin:auto;
  width:min(100%, 148px);
  max-height:186px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 18px 24px rgba(0,0,0,0.34)) drop-shadow(0 0 16px rgb(var(--public-class-rgb) / 0.20));
}
.public-char-slot-body{display:flex;flex-direction:column;gap:14px;min-width:0;justify-content:center;}
.public-char-slot-head{display:flex;gap:16px;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;}
.public-char-slot-titleblock{display:flex;flex-direction:column;gap:8px;min-width:0;}
.public-char-slot-overline{
  color:rgba(233,213,195,0.66);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.public-character-name{margin:0;font-size:34px;line-height:1.02;color:var(--public-text);}
.public-char-slot-classline{display:flex;align-items:center;gap:9px;flex-wrap:wrap;color:var(--public-muted);font-size:15px;line-height:1.35;}
.public-char-slot-raceline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--public-muted);font-size:14px;line-height:1.35;}
.public-char-slot-classicon{width:18px;height:18px;display:inline-block;filter:drop-shadow(0 0 10px rgb(var(--public-class-rgb) / 0.24));}
.public-char-slot-raceicon{width:18px;height:18px;display:block;object-fit:contain;filter:drop-shadow(0 0 10px rgba(255,255,255,0.12));}
.public-char-slot-racebadge{display:block;height:28px;width:auto;max-width:168px;filter:drop-shadow(0 8px 14px rgba(0,0,0,0.24));}
.public-char-slot-raceicon.is-hidden{display:none;}
.public-char-slot-classname{font-weight:900;letter-spacing:.01em;}
.public-char-slot-sep{color:rgba(233,213,195,0.42);font-weight:900;}
.public-char-slot-badges{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;}
.public-badge{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:8px 12px;border:1px solid rgba(184,146,123,0.18);background:rgba(255,255,255,0.03);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);}
.public-badge--strong{border-color:rgb(var(--public-class-rgb) / 0.30);background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.16), rgba(28,17,24,0.96));box-shadow:inset 0 0 0 1px rgb(var(--public-class-rgb) / 0.08);}
.public-char-slot-summary{display:flex;flex-wrap:wrap;gap:12px;}
.public-char-slot-summary-card{
  min-width:118px;
  padding:12px 14px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(34,22,28,0.86), rgba(10,7,13,0.96));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-char-slot-summary-card span{display:block;margin-bottom:6px;font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:rgba(233,213,195,0.62);}
.public-char-slot-summary-card strong{display:block;font-size:26px;line-height:1;color:var(--public-text);}
.public-char-slot-meters{display:grid;gap:12px;grid-template-columns:repeat(2, minmax(0,1fr));}
.public-resource-meter{
  padding:12px 14px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(34,22,28,0.80), rgba(10,7,13,0.94));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-resource-meter-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:10px;}
.public-resource-meter-head > span{font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:rgba(233,213,195,0.62);}
.public-resource-meter-head strong{font-size:15px;line-height:1;color:var(--public-text);font-variant-numeric:tabular-nums;}
.public-resource-meter-head strong > span{font:inherit;color:inherit;letter-spacing:inherit;text-transform:none;}
.public-resource-track{
  height:12px;
  border:1px solid rgba(184,146,123,0.18);
  background:rgba(7,5,9,0.86);
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.34);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  overflow:hidden;
}
.public-resource-track > span{display:block;height:100%;}
.public-resource-meter--hp .public-resource-track > span{background:linear-gradient(90deg, rgba(218,128,128,0.96), rgba(239,196,196,0.96));box-shadow:0 0 16px rgba(224,154,154,0.22);}
.public-resource-meter--mp .public-resource-track > span{background:linear-gradient(90deg, rgba(124,188,255,0.96), rgba(188,221,255,0.96));box-shadow:0 0 16px rgba(124,188,255,0.20);}
.public-char-slot-actions{display:flex;align-items:stretch;min-width:0;}
.public-char-slot-actions form{display:flex;width:100%;}
.public-char-slot-playbtn{
  width:100%;
  min-height:100%;
  flex-direction:column;
  gap:8px;
  padding:14px 14px 12px;
  border-color:rgb(var(--public-class-rgb) / 0.28) !important;
  background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.16), rgba(28,17,24,0.98)) !important;
  box-shadow:inset 0 0 0 1px rgb(var(--public-class-rgb) / 0.08), 0 12px 24px rgba(0,0,0,0.22) !important;
}
.public-char-slot-playbtn:hover{border-color:rgb(var(--public-class-rgb) / 0.42) !important;background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.22), rgba(34,20,28,0.99)) !important;}
.public-char-slot-playbtn strong{font-size:24px;line-height:1;color:var(--public-text);}
.public-char-slot-playbtn-kicker{font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,236,231,0.78);}
.public-char-slot-playbtn.is-disabled{pointer-events:none;opacity:.74;filter:saturate(.78);}
.public-char-add-card{display:flex;align-items:center;gap:18px;padding:18px;}
.public-char-add-card.is-locked{opacity:.82;border-style:dashed;}
.public-char-add-plus{
  width:72px;
  height:72px;
  flex:0 0 72px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(39,25,30,0.92), rgba(10,7,13,0.98));
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  font-size:40px;
  line-height:1;
  color:rgba(255,245,236,0.96);
  text-shadow:0 0 16px rgba(142,194,255,0.16);
}
.public-char-add-copy{display:flex;flex-direction:column;gap:6px;}
.public-char-add-copy strong{font-size:22px;line-height:1.08;color:var(--public-text);}
.public-char-add-copy span{color:var(--public-muted);line-height:1.5;}
.public-contact-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-start;margin-top:14px;}
.public-lobby-empty-state{display:flex;flex-direction:column;gap:14px;min-height:220px;justify-content:center;align-items:flex-start;}
.public-lobby-empty-state h3{margin:0;font-size:28px;line-height:1.08;color:var(--public-text);}
.public-lobby-empty-state p{margin:0;max-width:680px;color:var(--public-muted);line-height:1.6;}
@media (max-width: 980px){
  .public-hero,
  .public-grid,
  .public-lobby-grid,
  .public-char-slot-row,
  .public-char-add-row,
  .public-char-slot-card,
  .public-char-slot-meters{grid-template-columns:minmax(0,1fr);}
  .public-logo-wrap{max-width:220px;min-height:150px;justify-self:center;width:100%;}
  .public-hero-copy{text-align:center;}
  .public-nav{justify-content:center;}
  .public-char-slot-actions .btn{min-height:64px;}
  .public-char-slot-badges{justify-content:flex-start;}
}
@media (max-width: 760px){
  .public-frame{padding:18px;}
  .public-buttons,
  .public-buttons--dual,
  .public-feature-row,
  .public-status-grid,
  .public-char-slot-meters{grid-template-columns:minmax(0,1fr);}
  .public-shell{padding:18px 12px 18px;}
  .public-heading{font-size:clamp(28px, 7vw, 40px);}
  .public-panel,
  .public-panel-inset{padding:14px;}
  .public-form-actions,
  .public-contact-actions,
  .public-highlight-cta{flex-direction:column;}
  .public-form-actions .btn,
  .public-contact-actions .btn,
  .public-highlight-cta .btn{width:100%;}
  .public-form-actions--create-split .btn.primary{margin-left:0;}
  .public-char-slot-card{padding:12px;}
  .public-character-name{font-size:24px;}
  .public-char-slot-stage{min-height:176px;}
  .public-char-add-card{min-height:104px;}
}

.public-panel--landing-copy{
  padding-top:16px;
}
.public-panel-title--minimal{
  margin-bottom:0;
  padding-bottom:0;
}
.public-panel-title--minimal::after{
  display:none;
}
.public-story-pills{
  display:grid;
  gap:12px;
  grid-template-columns:repeat(3, minmax(0,1fr));
}
.public-story-pill{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-height:100%;
  padding:14px 15px;
  border:1px solid rgba(184,146,123,0.16);
  background:linear-gradient(180deg, rgba(18,12,19,0.88), rgba(8,5,11,0.96));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.02);
}
.public-story-pill strong{
  display:block;
  color:var(--public-text);
  font-size:14px;
  line-height:1.2;
}
.public-story-pill span{
  color:var(--public-muted);
  line-height:1.55;
  font-size:14px;
}
.public-reveal-card{
  position:relative;
  overflow:hidden;
  border:1px solid var(--public-border);
  background:linear-gradient(180deg, var(--public-shell-top), var(--public-shell-bottom));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 14px 32px rgba(0,0,0,0.28);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
  isolation:isolate;
  backface-visibility:hidden;
  transform:translateZ(0);
}
.public-reveal-card > summary{
  list-style:none;
}
.public-reveal-card > summary::-webkit-details-marker{
  display:none;
}
.public-reveal-trigger{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:18px 22px;
  cursor:pointer;
  user-select:none;
  background:
    linear-gradient(180deg, rgba(7,10,18,0.48), rgba(7,5,11,0.42)),
    url("../img/ui/public/login_bg.jpg") center center / cover no-repeat;
}
.public-reveal-trigger::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(7,10,18,0.88) 0%, rgba(7,8,14,0.64) 54%, rgba(7,5,11,0.82) 100%);
}
.public-reveal-trigger-copy,
.public-reveal-trigger-action{
  position:relative;
  z-index:1;
}
.public-reveal-trigger-copy{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-width:0;
}
.public-reveal-trigger-copy strong{
  display:block;
  font-size:28px;
  line-height:1.06;
  color:var(--public-text);
}
.public-reveal-trigger-copy > span:last-child{
  color:var(--public-muted);
  line-height:1.55;
}
.public-reveal-trigger-action{
  display:inline-flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
  min-height:42px;
  padding:10px 14px;
  border:1px solid rgba(184,146,123,0.24);
  background:linear-gradient(180deg, rgba(71,47,48,0.92), rgba(28,17,24,0.96));
  color:var(--public-text);
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-reveal-trigger-action::after{
  content:'+';
  font-size:20px;
  line-height:1;
  font-weight:700;
}
.public-reveal-card[open] .public-reveal-trigger-action::after{
  content:'−';
}
.public-reveal-body{
  border-top:1px solid rgba(184,146,123,0.14);
  background:linear-gradient(180deg, rgba(13,9,16,0.92), rgba(7,5,10,0.98));
}
.public-reveal-body-inner{
  padding:18px;
}
.js-public-portal .public-reveal-card[data-animated]{
  overflow:hidden;
  contain:layout paint;
}
.js-public-portal .public-reveal-card[data-animated] .public-reveal-body{
  overflow:hidden;
  height:0;
  opacity:0;
  border-top-color:transparent;
  transition:
    height var(--public-reveal-height-duration, 340ms) cubic-bezier(.22,.9,.3,1),
    opacity 180ms ease,
    border-color 220ms ease;
  will-change:height,opacity;
}
.js-public-portal .public-reveal-card[data-animated] .public-reveal-body-inner{
  opacity:0;
  transform:translate3d(0,-10px,0) scale(.992);
  transform-origin:top center;
  transition:
    opacity var(--public-reveal-inner-duration, 240ms) ease,
    transform var(--public-reveal-inner-duration, 300ms) cubic-bezier(.22,1,.36,1);
  will-change:transform,opacity;
}
.js-public-portal .public-reveal-card[data-animated].is-expanded .public-reveal-body,
.js-public-portal .public-reveal-card[data-animated].is-opening .public-reveal-body{
  opacity:1;
  border-top-color:rgba(184,146,123,0.14);
}
.js-public-portal .public-reveal-card[data-animated].is-expanded .public-reveal-body-inner,
.js-public-portal .public-reveal-card[data-animated].is-opening .public-reveal-body-inner{
  opacity:1;
  transform:none;
}
.js-public-portal .public-reveal-card[data-animated].is-closing .public-reveal-body{
  opacity:0;
}

.js-public-portal [data-auto-reveal="1"]{
  opacity:0;
  transform:translate3d(0,12px,0);
  filter:saturate(.94);
  transition:
    opacity 260ms ease,
    transform 420ms cubic-bezier(.22,1,.36,1),
    filter 420ms ease;
  will-change:transform,opacity,filter;
}
.js-public-portal [data-auto-reveal="1"].is-auto-revealing,
.js-public-portal [data-auto-reveal="1"].is-auto-revealed{
  opacity:1;
  transform:none;
  filter:none;
}
@media (prefers-reduced-motion: reduce){
  .js-public-portal .public-reveal-card[data-animated] .public-reveal-body,
  .js-public-portal .public-reveal-card[data-animated] .public-reveal-body-inner,
  .js-public-portal [data-auto-reveal="1"]{
    transition:none !important;
  }
}
.public-media-frame{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(15,10,16,0.96), rgba(8,5,11,0.99));
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.02);
}
.public-media-frame--video{
  aspect-ratio:16 / 9;
}
.public-media-frame--video iframe,
.public-media-frame--video video{
  width:100%;
  height:100%;
  display:block;
  border:0;
  background:#000;
}
.public-media-frame--intro{
  display:grid;
  gap:18px;
  grid-template-columns:minmax(280px, 1.15fr) minmax(260px, .85fr);
  align-items:stretch;
  min-height:360px;
}
.public-media-stage{
  position:relative;
  min-height:320px;
  background:
    linear-gradient(180deg, rgba(7,10,18,0.36), rgba(7,5,11,0.72)),
    url("../img/ui/public/login_bg.jpg") center center / cover no-repeat;
}
.public-media-stage--video{
  overflow:hidden;
  background:#000;
}
.public-media-stage--video::before{
  display:none;
}
.public-media-stage--video iframe,
.public-media-stage--video video{
  width:100%;
  height:100%;
  display:block;
  border:0;
  background:#000;
}
.public-embed-gate{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:18px;
  padding:24px;
  background:
    linear-gradient(180deg, rgba(6,10,18,.78), rgba(5,6,12,.92)),
    radial-gradient(circle at 50% 35%, rgba(132,194,255,.16), rgba(0,0,0,0) 50%);
}
.public-embed-gate.is-loaded{
  padding:0;
  background:#000;
}
.public-embed-gate.is-loaded iframe{
  width:100%;
  height:100%;
  display:block;
  border:0;
  background:#000;
}
.public-embed-gate__copy{
  display:flex;
  flex-direction:column;
  gap:8px;
  max-width:42ch;
}
.public-embed-gate__copy strong{
  font-size:24px;
  line-height:1.06;
  color:var(--public-text);
}
.public-embed-gate__copy span{
  color:var(--public-muted);
  line-height:1.6;
}
.public-embed-gate__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.public-embed-gate__button,
.public-embed-gate__link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid rgba(184,146,123,.24);
  background:rgba(255,255,255,.06);
  color:var(--public-text);
  font-weight:800;
  letter-spacing:.02em;
  text-decoration:none;
}
.public-embed-gate__button{
  cursor:pointer;
}
.public-embed-gate__button:hover,
.public-embed-gate__button:focus-visible,
.public-embed-gate__link:hover,
.public-embed-gate__link:focus-visible{
  border-color:rgba(230,195,170,.38);
  background:rgba(255,255,255,.1);
  outline:none;
}
.public-media-stage::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 50%, rgba(130,190,255,0.18) 0%, rgba(0,0,0,0) 42%);
}
.public-media-stage-logo{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
}
.public-media-stage-logo img{
  width:min(62%, 280px);
  height:auto;
  filter:drop-shadow(0 12px 28px rgba(0,0,0,0.44)) drop-shadow(0 0 24px rgba(142,194,255,0.22));
}
.public-media-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:12px;
  padding:22px 22px 24px 0;
}
.public-media-copy h3{
  margin:0;
  font-size:28px;
  line-height:1.08;
  color:var(--public-text);
}
.public-media-copy p{
  margin:0;
  color:var(--public-muted);
  line-height:1.62;
}
.public-media-copy-points{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:4px;
}
.public-media-copy-points span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 12px;
  border:1px solid rgba(184,146,123,0.18);
  background:rgba(255,255,255,0.025);
  color:var(--public-text);
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}


.public-world-intro-panel{display:flex;flex-direction:column;gap:18px;}
.public-world-intro-panel .public-panel-title p{max-width:920px;}
.public-world-intro-video{margin-bottom:2px;}
.public-world-intro-frame{--public-class-rgb:212 169 107;grid-template-columns:minmax(300px, 1.02fr) minmax(320px, .98fr);min-height:420px;}
.public-world-intro-stage{
  background:
    radial-gradient(circle at 50% 20%, rgb(var(--public-class-rgb) / 0.20), rgba(0,0,0,0) 32%),
    linear-gradient(180deg, rgba(7,10,18,0.34), rgba(7,5,11,0.76)),
    var(--public-world-intro-stage-bg) center center / cover no-repeat;
}
.public-world-intro-stage::after{
  content:'';
  position:absolute;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  width:72%;
  height:26px;
  background:radial-gradient(circle at 50% 50%, rgb(var(--public-class-rgb) / 0.26) 0%, rgba(0,0,0,0) 72%);
  filter:blur(10px);
  opacity:.92;
}
.public-world-intro-stage-glow{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 58%, rgb(var(--public-class-rgb) / 0.18), rgba(0,0,0,0) 42%);
  pointer-events:none;
}
.public-world-intro-avatar{
  position:relative;
  z-index:1;
  display:block;
  margin:auto;
  width:min(72%, 264px);
  max-height:304px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 24px 32px rgba(0,0,0,0.42)) drop-shadow(0 0 22px rgb(var(--public-class-rgb) / 0.24));
}
.public-world-intro-copy{padding-right:20px;}
.public-world-intro-classline{display:flex;flex-wrap:wrap;align-items:center;gap:10px;color:var(--public-muted);font-size:14px;line-height:1.45;}
.public-world-intro-classline strong{font-size:18px;line-height:1;color:var(--public-text);}
.public-world-intro-classicon{width:18px;height:18px;display:block;object-fit:contain;filter:drop-shadow(0 0 12px rgb(var(--public-class-rgb) / 0.24));}
.public-world-intro-sep{color:rgba(233,213,195,0.42);font-weight:900;}
.public-world-intro-points span{border-color:rgb(var(--public-class-rgb) / 0.22);background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.12), rgba(19,11,18,0.94));}
.public-world-intro-identity{
  --public-class-rgb:212 169 107;
  display:flex;
  flex-direction:column;
  gap:16px;
  padding:18px;
  border:1px solid rgba(184,146,123,0.18);
  background:
    radial-gradient(circle at 14% 18%, rgb(var(--public-class-rgb) / 0.10), rgba(0,0,0,0) 26%),
    linear-gradient(180deg, rgba(20,13,20,0.96), rgba(9,6,12,0.99));
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}
.public-world-intro-head{display:flex;gap:18px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;}
.public-world-intro-titleblock{display:flex;flex-direction:column;gap:8px;min-width:0;}
.public-world-intro-overline{color:rgba(233,213,195,0.66);font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;}
.public-world-intro-titleline{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.public-world-intro-titleline h3{margin:0;font-size:32px;line-height:1.04;color:var(--public-text);}
.public-world-intro-titleblock p{margin:0;max-width:760px;color:var(--public-muted);line-height:1.62;}
.public-world-intro-chip{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 12px;
  border:1px solid rgb(var(--public-class-rgb) / 0.28);
  background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.16), rgba(28,17,24,0.96));
  color:var(--public-text);
  font-size:12px;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-racebadge{display:block;max-width:min(200px, 100%);width:auto;height:34px;filter:drop-shadow(0 10px 18px rgba(0,0,0,0.26));}
.public-world-intro-meta{display:grid;gap:12px;grid-template-columns:repeat(3, minmax(0,1fr));}
.public-world-intro-meta-card{
  padding:14px 15px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(35,23,28,0.88), rgba(11,7,13,0.96));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-meta-card span{display:block;margin-bottom:8px;color:rgba(233,213,195,0.66);font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;}
.public-world-intro-meta-card strong{display:flex;align-items:center;gap:10px;min-width:0;font-size:18px;line-height:1.18;color:var(--public-text);}
.public-world-intro-meta-icon{width:18px;height:18px;display:block;object-fit:contain;flex:0 0 auto;filter:drop-shadow(0 0 12px rgb(var(--public-class-rgb) / 0.18));}
.public-world-intro-note{color:var(--public-muted);line-height:1.65;}
.public-world-intro-actions{display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap;}
.public-world-intro-form{display:flex;gap:12px;align-items:center;justify-content:flex-end;flex-wrap:wrap;}

@media (max-width: 980px){
  .public-world-intro-frame{grid-template-columns:minmax(0,1fr);min-height:0;}
  .public-world-intro-copy{padding-right:0;}
  .public-world-intro-meta{grid-template-columns:repeat(2, minmax(0,1fr));}
}
@media (max-width: 760px){
  .public-world-intro-avatar{width:min(74%, 220px);max-height:240px;}
  .public-world-intro-titleline h3{font-size:26px;}
  .public-world-intro-meta{grid-template-columns:minmax(0,1fr);}
  .public-world-intro-actions{align-items:stretch;}
  .public-world-intro-actions > .btn,
  .public-world-intro-form{width:100%;}
  .public-world-intro-form .btn{flex:1 1 100%;width:100%;}
}

@media (max-width: 980px){
  .public-story-pills,
  .public-media-frame--intro{
    grid-template-columns:minmax(0,1fr);
  }
  .public-media-copy{
    padding:0 18px 20px;
  }
}
@media (max-width: 760px){
  .public-reveal-trigger{
    padding:16px 14px;
    flex-direction:column;
    align-items:flex-start;
  }
  .public-reveal-trigger-copy strong{
    font-size:24px;
  }
  .public-reveal-trigger-action{
    width:100%;
    justify-content:space-between;
  }
  .public-reveal-body-inner{
    padding:14px;
  }
  .public-media-frame--intro{
    min-height:0;
  }
  .public-media-stage{
    min-height:240px;
  }
}

.public-index-actionbar{
  display:grid;
  gap:12px;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr) minmax(58px,.17fr) minmax(58px,.17fr);
  align-items:stretch;
}
.public-index-actionbar .btn{width:100%;}
.public-index-actionbar .btn.is-active{border-color:rgba(142,194,255,0.34);box-shadow:inset 0 0 0 1px rgba(142,194,255,0.10), 0 8px 18px rgba(0,0,0,0.22);}
.public-index-actionbar .btn.is-disabled{pointer-events:none;opacity:.48;filter:saturate(.72);}
.public-index-actionbar__faq{padding-left:8px;padding-right:8px;font-size:14px;}
.public-index-actionbar__icon{padding:0;min-width:0;}
.public-icon-house{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;}
.public-icon-house svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.public-page-index .public-reveal-trigger-copy{gap:8px;}
.public-page-index .public-reveal-trigger-copy strong{font-size:26px;}
.public-page-index .public-reveal-trigger-copy > span:last-child{max-width:760px;}

@media (max-width: 760px){
  .public-frame-beta{top:12px;right:12px;transform:none;}
  .public-index-actionbar{grid-template-columns:repeat(2, minmax(0,1fr));}
  .public-index-actionbar .btn:first-child,
  .public-index-actionbar .btn:nth-child(2),
  .public-index-actionbar .btn:nth-child(3){grid-column:span 2;}
}

.public-faq-grid{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(2, minmax(0,1fr));
}
.public-faq-card{
  display:flex;
  flex-direction:column;
  gap:8px;
  min-height:100%;
  padding:16px 16px 17px;
  border:1px solid rgba(184,146,123,0.16);
  background:linear-gradient(180deg, rgba(18,12,19,0.90), rgba(8,5,11,0.98));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.02);
  scroll-margin-top:22px;
}
.public-faq-card strong{
  display:block;
  color:var(--public-text);
  font-size:18px;
  line-height:1.18;
}
.public-faq-card p{
  margin:0;
  color:var(--public-muted);
  line-height:1.62;
}

.public-portal-grid{
  display:grid;
  gap:18px;
  grid-template-columns:minmax(0, 1.04fr) minmax(300px, .96fr);
  align-items:start;
}
.public-portal-column{
  display:flex;
  flex-direction:column;
  gap:14px;
  min-width:0;
}

@media (max-width: 980px){
  .public-portal-grid{grid-template-columns:minmax(0,1fr);}
}

@media (max-width: 760px){
  .public-faq-grid{grid-template-columns:minmax(0,1fr);}
}

.public-lobby-flow-note{margin:0;color:var(--public-muted);line-height:1.6;}
.public-create-form{display:flex;flex-direction:column;gap:15px;}
.public-create-form .label{margin-bottom:7px;letter-spacing:.015em;}
.public-create-form .input{min-height:48px;font-weight:700;line-height:1.2;transition:border-color .14s ease, box-shadow .14s ease, background .14s ease, transform .14s ease;}
.public-create-form .input:hover{border-color:rgba(206,168,143,0.30);background:linear-gradient(180deg, rgba(43,28,35,.98), rgba(18,11,18,.99));}
.public-create-form .input::placeholder{color:rgba(233,213,195,0.42);font-weight:600;}
body.public-page .public-create-form select.input{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:42px;color:var(--public-text);color-scheme:dark;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 4.25 6 8l4-3.75' fill='none' stroke='%23e9d5c3' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"), linear-gradient(180deg, rgba(35,23,28,.98), rgba(17,10,17,.99));background-repeat:no-repeat,no-repeat;background-position:right 13px center,0 0;background-size:12px 12px,100% 100%;}
body.public-page .public-create-form select.input option,
body.public-page .public-create-form select.input optgroup{background:#130d15;color:#f2e7df;}
body.public-page .public-create-form select.input option:checked{background:#2b1c24;color:#fff7f0;}
body.public-page .public-create-form select.input:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 4.25 6 8l4-3.75' fill='none' stroke='%23d8ecff' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"), linear-gradient(180deg, rgba(43,28,35,.99), rgba(18,11,18,.995));}
.public-create-top-grid{display:grid;gap:15px 14px;grid-template-columns:minmax(0,1.08fr) minmax(270px,.92fr);align-items:start;}
.public-create-top-cell{min-width:0;}
.public-create-form-grid{display:grid;gap:15px 14px;grid-template-columns:repeat(2, minmax(0,1fr));}
body.public-page fieldset.public-create-choice-group{display:flex;flex-direction:column;margin:0;padding:0;border:0;min-width:0;}
body.public-page fieldset.public-create-choice-group .label{margin:0 0 7px;}
.public-create-gender-grid{display:grid;gap:10px;grid-template-columns:repeat(2, minmax(0,1fr));}
.public-create-gender-choice{position:relative;display:block;cursor:pointer;user-select:none;}
.public-create-gender-choice-input{position:absolute;inset:0;opacity:0;pointer-events:none;}
.public-create-gender-choice-card{display:flex;align-items:center;gap:10px;min-height:48px;padding:12px 14px;border:1px solid rgba(164,129,111,0.18);background:linear-gradient(180deg, rgba(35,23,28,.96), rgba(17,10,17,.98));box-shadow:inset 0 1px 0 rgba(255,255,255,.015);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);transition:border-color .14s ease, box-shadow .14s ease, transform .14s ease, background .14s ease;}
.public-create-gender-choice:hover .public-create-gender-choice-card{border-color:rgba(206,168,143,0.34);background:linear-gradient(180deg, rgba(44,29,35,.98), rgba(20,12,19,.99));transform:translateY(-1px);}
.public-create-gender-choice-input:checked + .public-create-gender-choice-card{border-color:rgba(142,194,255,0.34);box-shadow:inset 0 0 0 1px rgba(142,194,255,0.10), 0 8px 18px rgba(0,0,0,.22);background:linear-gradient(180deg, rgba(48,33,40,.98), rgba(18,11,18,.99));}
.public-create-gender-choice-input:focus-visible + .public-create-gender-choice-card{outline:none;border-color:rgba(142,194,255,0.34);box-shadow:inset 0 0 0 1px rgba(142,194,255,0.10), 0 0 0 2px rgba(142,194,255,0.07);}
.public-create-gender-choice-icon{width:24px;height:24px;display:block;flex:0 0 24px;object-fit:contain;filter:drop-shadow(0 0 14px rgba(255,255,255,0.10));}
.public-create-gender-choice-icon--fallback{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(255,255,255,0.12);font-size:13px;font-weight:900;color:var(--public-text);background:rgba(255,255,255,0.04);}
.public-create-gender-choice-label{font-size:14px;font-weight:800;line-height:1.1;color:var(--public-text);}
.public-create-top-cell--gender .public-create-gender-choice-card{min-height:48px;padding:11px 12px;}
.public-create-top-cell--gender .public-create-gender-choice-label{font-size:13px;}
.public-create-note{margin:0;color:var(--public-muted);line-height:1.6;}
.public-create-preview{
  --public-class-rgb:212 169 107;
  --public-class-color:#d4a96b;
  --public-race-rgb:207 167 106;
  --public-hair-rgb:124 88 58;
  display:flex;
  flex-direction:column;
  gap:10px;
  box-sizing:border-box;
  min-height:var(--public-create-shared-height, auto);
}
@media (min-width: 981px){
  .public-portal-grid [data-create-reference="1"],
  .public-portal-grid [data-create-preview="1"]{min-height:var(--public-create-shared-height, auto);}
  .public-portal-grid [data-create-reference="1"]{display:flex;flex-direction:column;}
  .public-portal-grid [data-create-reference="1"] > .public-form,
  .public-portal-grid [data-create-reference="1"] > .public-lobby-empty-state{display:flex;flex-direction:column;flex:1 1 auto;}
  .public-portal-grid [data-create-reference="1"] > .public-form .public-form-actions--create-split,
  .public-portal-grid [data-create-reference="1"] > .public-lobby-empty-state .public-form-actions{margin-top:auto;}
}
.public-create-preview-card{
  position:relative;
  overflow:hidden;
  flex:1 1 auto;
  min-height:0;
  display:grid;
  grid-template-columns:minmax(140px, 156px) minmax(0, 1fr);
  grid-template-areas:
    'stage main'
    'stage meters'
    'attrs attrs';
  align-content:start;
  gap:12px 14px;
  padding:14px;
  border:1px solid rgb(var(--public-class-rgb) / 0.24);
  background:
    radial-gradient(circle at 14% 16%, rgb(var(--public-class-rgb) / 0.16), rgba(0,0,0,0) 26%),
    radial-gradient(circle at 84% 12%, rgb(var(--public-hair-rgb) / 0.14), rgba(0,0,0,0) 22%),
    linear-gradient(180deg, rgba(38,25,31,0.97), rgba(11,8,14,0.985));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04), inset 0 0 0 1px rgba(255,255,255,0.02), 0 18px 40px rgba(0,0,0,0.24);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
}
.public-create-preview-card::before,
.public-create-preview-card::after{content:'';position:absolute;pointer-events:none;}
.public-create-preview-card::before{left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.96), rgb(var(--public-class-rgb) / 0.16));}
.public-create-preview-card::after{inset:0;background:linear-gradient(90deg, rgba(255,255,255,0.025), rgba(255,255,255,0) 38%, rgb(var(--public-class-rgb) / 0.08) 100%);}
.public-create-preview-card > *{position:relative;z-index:1;}
.public-create-preview-stage{
  grid-area:stage;
  position:relative;
  min-height:202px;
  display:grid;
  place-items:end center;
  padding:18px 14px 14px;
  border:1px solid rgb(var(--public-class-rgb) / 0.20);
  background:
    radial-gradient(circle at 50% 16%, rgb(var(--public-hair-rgb) / 0.24), rgba(0,0,0,0) 26%),
    radial-gradient(circle at 50% 78%, rgb(var(--public-class-rgb) / 0.20), rgba(0,0,0,0) 36%),
    linear-gradient(180deg, rgba(41,27,34,0.96), rgba(10,7,13,0.995));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), inset 0 0 0 1px rgba(255,255,255,0.015);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  overflow:hidden;
  isolation:isolate;
}
.public-create-preview-stage::before{content:'';position:absolute;inset:0;background:var(--public-lobby-stage-bg, none) center bottom / cover no-repeat;opacity:.26;mix-blend-mode:screen;}
.public-create-preview-stage::after{content:'';position:absolute;left:50%;bottom:10px;transform:translateX(-50%);width:74%;height:22px;background:radial-gradient(circle at 50% 50%, rgb(var(--public-class-rgb) / 0.34) 0%, rgba(0,0,0,0) 70%);filter:blur(8px);}
.public-create-preview-stage-halo{position:absolute;left:50%;top:8%;transform:translateX(-50%);width:min(76%, 180px);height:94px;background:radial-gradient(circle at 50% 50%, rgb(var(--public-hair-rgb) / 0.28), rgba(0,0,0,0) 72%);filter:blur(20px);opacity:.86;transition:background .2s ease, opacity .2s ease;}
.public-create-preview-avatar{
  position:relative;
  z-index:2;
  display:block;
  margin:auto;
  width:min(100%, 138px);
  max-height:176px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 18px 24px rgba(0,0,0,0.36)) drop-shadow(0 0 20px rgb(var(--public-class-rgb) / 0.26));
  transition:transform .22s ease, filter .22s ease, opacity .18s ease;
}
.public-create-preview.is-syncing .public-create-preview-avatar{transform:translateY(-2px) scale(1.022);}
.public-create-preview.is-syncing .public-create-preview-stage-halo{opacity:.94;}
.public-create-preview-main{grid-area:main;position:relative;display:flex;flex-direction:column;gap:10px;min-width:0;align-self:stretch;padding-top:2px;}
.public-create-preview-main::before{content:'';position:absolute;left:-8px;top:4px;bottom:4px;width:1px;background:linear-gradient(180deg, rgba(255,255,255,0), rgb(var(--public-class-rgb) / 0.24) 16%, rgb(var(--public-class-rgb) / 0.08) 84%, rgba(255,255,255,0));pointer-events:none;}
.public-create-preview-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.public-create-preview-toolbar .public-eyebrow{margin:0;}
.public-create-preview-status{min-width:50px;justify-content:center;border-color:rgb(var(--public-class-rgb) / 0.30);background:linear-gradient(180deg, rgb(var(--public-class-rgb) / 0.16), rgba(28,17,24,0.96));box-shadow:inset 0 0 0 1px rgb(var(--public-class-rgb) / 0.08);}
.public-create-preview-titleblock{display:flex;flex-direction:column;gap:4px;min-width:0;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,0.06);}
.public-create-preview-name{margin:0;font-size:clamp(26px, 2vw, 30px);line-height:0.98;overflow-wrap:anywhere;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 2px 12px rgba(0,0,0,0.16);}
.public-create-preview-classline{display:flex;align-items:center;gap:9px;flex-wrap:wrap;min-height:20px;}
.public-create-preview-classicon{filter:drop-shadow(0 0 16px rgb(var(--public-class-rgb) / 0.26));}
.public-create-preview-classicon.is-hidden{display:none;}
.public-create-preview-classname{font-size:17px;line-height:1.1;font-weight:800;overflow-wrap:anywhere;}
.public-create-preview-blurb{margin:0;min-height:52px;color:rgba(233,213,195,0.78);font-size:12.5px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.public-create-preview-details{display:grid;gap:8px;grid-template-columns:repeat(3, minmax(0,1fr));grid-auto-rows:minmax(66px, auto);}
.public-create-preview-detail{min-width:0;position:relative;display:flex;flex-direction:column;justify-content:space-between;min-height:66px;padding:9px 10px 10px;border:1px solid rgba(184,146,123,0.20);background:linear-gradient(180deg, rgba(35,23,30,0.90), rgba(9,6,12,0.97));box-shadow:inset 0 1px 0 rgba(255,255,255,0.025), 0 8px 16px rgba(0,0,0,0.12);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);}
.public-create-preview-detail--gender{border-color:rgba(160,189,255,0.20);}
.public-create-preview-detail--hair{border-color:rgba(205,170,124,0.20);}
.public-create-preview-detail--haircolor{border-color:rgb(var(--public-hair-rgb) / 0.28);}
.public-create-preview-detail--race{grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) minmax(116px, 132px);align-items:center;gap:10px 12px;min-height:64px;padding:10px 12px;border-color:rgb(var(--public-race-rgb) / 0.34);background:linear-gradient(180deg, rgb(var(--public-race-rgb) / 0.16), rgba(10,7,13,0.96));box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 10px 20px rgba(0,0,0,0.14);}
.public-create-preview-detail > span{display:block;margin-bottom:5px;font-size:10px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:rgba(233,213,195,0.60);}
.public-create-preview-detail strong{display:flex;align-items:center;justify-content:flex-start;gap:8px;font-size:15px;line-height:1.18;color:var(--public-text);min-width:0;min-height:24px;margin-top:auto;}
.public-create-preview-detail strong > span{display:block;margin:0;font-size:inherit;font-weight:inherit;letter-spacing:inherit;text-transform:none;color:inherit;}
.public-create-preview-gender{min-height:24px;}
.public-create-preview-gendericon{width:22px;height:22px;display:block;flex:0 0 22px;object-fit:contain;filter:drop-shadow(0 0 14px rgba(255,255,255,0.10));}
.public-create-preview-gendericon.is-hidden{display:none;}
.public-create-preview-gendertext.is-hidden{display:none;}
.public-create-preview-detail--race strong{grid-column:1 / 2;align-self:center;margin-top:0;font-weight:800;}
.public-create-preview-racevalue{display:flex;align-items:center;gap:10px;min-width:0;min-height:24px;}
.public-create-preview-racevalue > span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.public-create-preview-raceicon{width:18px;height:18px;display:block;flex:0 0 18px;object-fit:contain;filter:drop-shadow(0 0 12px rgba(255,255,255,0.14));}
.public-create-preview-raceicon.is-hidden,.public-create-preview-racebadge.is-hidden{display:none;}
.public-create-preview-racebadge{grid-column:2 / 3;grid-row:1 / 2;align-self:center;justify-self:end;display:block;width:min(100%, 124px);max-height:24px;height:auto;object-fit:contain;filter:drop-shadow(0 10px 16px rgba(0,0,0,0.22));}
.public-create-preview-haircolor{display:flex;align-items:center;gap:7px;}
.public-create-preview-swatch{width:12px;height:12px;display:inline-block;flex:0 0 12px;border-radius:999px;border:1px solid rgba(255,255,255,0.18);background:rgb(var(--swatch-rgb) / 0.98);box-shadow:0 0 14px rgb(var(--swatch-rgb) / 0.34);}
.public-create-preview-meters{grid-area:meters;align-self:stretch;gap:8px;margin-top:0;grid-template-columns:repeat(2, minmax(0,1fr));}
.public-create-preview-meters .public-resource-meter{padding:10px 11px;min-height:62px;box-shadow:inset 0 1px 0 rgba(255,255,255,0.025), 0 10px 18px rgba(0,0,0,0.12);}
.public-create-preview-meters .public-resource-meter--hp{border-color:rgba(224,154,154,0.20);background:linear-gradient(180deg, rgba(49,24,29,0.88), rgba(10,7,13,0.96));}
.public-create-preview-meters .public-resource-meter--mp{border-color:rgba(124,188,255,0.20);background:linear-gradient(180deg, rgba(23,30,42,0.88), rgba(10,7,13,0.96));}
.public-create-preview-meters .public-resource-meter-head{margin-bottom:7px;gap:8px;align-items:baseline;}
.public-create-preview-meters .public-resource-meter-head > span{font-size:10px;letter-spacing:.16em;min-width:0;color:rgba(233,213,195,0.58);}
.public-create-preview-meters .public-resource-meter-head strong{font-size:15px;min-width:78px;text-align:right;}
.public-create-preview-meters .public-resource-track{height:8px;}
.public-create-preview-attrs{grid-area:attrs;display:grid;gap:7px;grid-template-columns:repeat(5, minmax(0,1fr));align-self:end;}
.public-create-preview-attr{min-width:0;min-height:52px;padding:7px 6px;border:1px solid rgba(184,146,123,0.20);background:linear-gradient(180deg, rgba(35,22,28,0.90), rgba(10,7,13,0.97));box-shadow:inset 0 1px 0 rgba(255,255,255,0.02), 0 8px 16px rgba(0,0,0,0.12);clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);text-align:center;display:flex;flex-direction:column;justify-content:center;}
.public-create-preview-attr span{display:block;margin:0 0 4px;font-size:9px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:rgba(233,213,195,0.58);}
.public-create-preview-attr strong{display:block;margin-top:0;font-size:16px;line-height:1;color:var(--public-text);font-variant-numeric:tabular-nums;}
@media (max-width: 980px){
  .public-create-preview{min-height:auto;}
  .public-create-preview-card{grid-template-columns:minmax(0,1fr);grid-template-areas:'main' 'stage' 'meters' 'attrs';}
  .public-create-preview-main{padding-top:0;}
  .public-create-preview-main::before{display:none;}
  .public-create-preview-blurb{min-height:0;}
  .public-create-preview-meters{align-self:auto;}
}
@media (max-width: 760px){
  .public-create-top-grid,.public-create-form-grid{grid-template-columns:minmax(0,1fr);}
  .public-create-preview-card{gap:10px 12px;padding:13px;}
  .public-create-preview-stage{min-height:192px;padding:18px 14px 14px;}
  .public-create-preview-avatar{width:min(100%, 162px);max-height:188px;}
  .public-create-preview-name{font-size:24px;}
  .public-create-preview-details{grid-template-columns:minmax(0,1fr);grid-auto-rows:auto;}
  .public-create-preview-detail{min-height:60px;}
  .public-create-preview-detail--race{grid-column:auto;grid-template-columns:minmax(0,1fr) auto;min-height:auto;}
  .public-create-preview-racebadge{grid-column:2 / 3;grid-row:1 / 2;justify-self:end;align-self:center;width:min(100%, 136px);max-height:24px;}
  .public-create-preview-meters{grid-template-columns:minmax(0,1fr);}
  .public-create-preview-attrs{grid-template-columns:repeat(3, minmax(0,1fr));}
}
.public-lobby-panel .public-panel-title p{max-width:900px;}
.public-reveal-card--portal{margin-top:16px;}
.public-reveal-card--portal .public-reveal-trigger-copy strong{font-size:24px;}
.public-reveal-card--portal .public-reveal-trigger-copy > span:last-child{max-width:860px;}
@media (max-width: 760px){
  .public-create-top-grid,.public-create-form-grid{grid-template-columns:minmax(0,1fr);}
  .public-create-preview-stage{min-height:188px;padding:18px 14px 12px;}
  .public-create-preview-avatar{width:min(100%, 160px);max-height:184px;}
  .public-create-preview-name{font-size:24px;}
  .public-create-preview-details{grid-template-columns:minmax(0,1fr);grid-auto-rows:auto;}
  .public-create-preview-detail{min-height:60px;}
  .public-create-preview-detail--race{grid-column:auto;grid-template-columns:minmax(0,1fr) auto;min-height:auto;}
  .public-create-preview-racebadge{grid-column:2 / 3;grid-row:1 / 2;justify-self:end;align-self:center;width:min(100%, 136px);max-height:24px;}
  .public-create-preview-meters{grid-template-columns:minmax(0,1fr);}
  .public-create-preview-attrs{grid-template-columns:repeat(3, minmax(0,1fr));}
}


.public-world-intro-grid{
  display:grid;
  gap:18px;
  grid-template-columns:minmax(0,1.14fr) minmax(300px,.86fr);
  align-items:start;
}
.public-world-intro-panel{padding-bottom:20px;}
.public-world-intro-stagecard{
  position:relative;
  overflow:hidden;
  min-height:460px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(14,9,16,0.96), rgba(8,5,11,0.99));
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.03), 0 14px 30px rgba(0,0,0,0.26);
}
.public-world-intro-stagecard::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 24% 18%, rgba(142,194,255,0.18), rgba(0,0,0,0) 28%),
    radial-gradient(circle at 72% 68%, rgba(212,169,107,0.18), rgba(0,0,0,0) 34%),
    linear-gradient(180deg, rgba(7,10,18,0.22), rgba(7,5,11,0.76)),
    url("../img/ui/public/login_bg.jpg") center center / cover no-repeat;
  opacity:.98;
}
.public-world-intro-stagecard > *{position:relative;z-index:1;}
.public-world-intro-stagehead{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
  padding:16px 18px 0;
}
.public-world-intro-overline{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 12px;
  border:1px solid rgba(184,146,123,0.18);
  background:rgba(255,255,255,0.04);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(244,236,231,0.82);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-live{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:52px;
  min-height:40px;
  padding:8px 14px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(68,45,46,0.92), rgba(26,16,23,0.98));
  color:var(--public-text);
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-visual{
  position:relative;
  min-height:300px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:42px 26px 112px;
}
.public-world-intro-visual::before{
  content:'';
  position:absolute;
  left:50%;
  top:52%;
  width:min(66%, 320px);
  aspect-ratio:1 / 1;
  transform:translate(-50%, -50%);
  border-radius:50%;
  background:radial-gradient(circle at 50% 50%, rgba(var(--intro-accent-rgb, 212 169 107) / 0.34) 0%, rgba(0,0,0,0) 72%);
  filter:blur(10px);
}
.public-world-intro-logo{
  position:absolute;
  left:50%;
  top:46%;
  transform:translate(-50%, -50%);
  width:min(40%, 170px);
  filter:drop-shadow(0 14px 28px rgba(0,0,0,0.44)) drop-shadow(0 0 22px rgba(var(--intro-accent-rgb, 212 169 107) / 0.24));
  opacity:.68;
}
.public-world-intro-avatar{
  position:relative;
  z-index:2;
  width:min(44%, 220px);
  max-width:220px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,0.42)) drop-shadow(0 0 22px rgba(var(--intro-accent-rgb, 212 169 107) / 0.24));
}
.public-world-intro-stagefloor{
  position:absolute;
  left:50%;
  bottom:66px;
  width:min(58%, 280px);
  height:24px;
  transform:translateX(-50%);
  border-radius:999px;
  background:radial-gradient(circle at 50% 50%, rgba(var(--intro-accent-rgb, 212 169 107) / 0.36) 0%, rgba(0,0,0,0) 72%);
  filter:blur(4px);
}
.public-world-intro-charmeta{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.public-world-intro-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:36px;
  padding:8px 12px;
  border:1px solid rgba(184,146,123,0.18);
  background:rgba(10,6,12,0.82);
  color:var(--public-text);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-chip img{display:block;width:18px;height:18px;object-fit:contain;}
.public-world-intro-progress{
  display:flex;
  flex-direction:column;
  gap:10px;
  padding:14px 18px 18px;
  border-top:1px solid rgba(184,146,123,0.14);
  background:linear-gradient(180deg, rgba(10,6,12,0.76), rgba(6,4,9,0.92));
}
.public-world-intro-progress-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}
.public-world-intro-progress-head span{
  color:rgba(244,236,231,0.78);
  font-size:12px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.public-world-intro-progress-head strong{
  color:var(--public-text);
  font-size:15px;
  line-height:1;
  font-variant-numeric:tabular-nums;
}
.public-world-intro-progress-track{
  position:relative;
  overflow:hidden;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(184,146,123,0.16);
  background:rgba(255,255,255,0.05);
}
.public-world-intro-progress-track > span{
  display:block;
  width:0%;
  height:100%;
  background:linear-gradient(90deg, rgba(var(--intro-accent-rgb, 212 169 107) / 0.96), rgba(188,221,255,0.94));
  box-shadow:0 0 18px rgba(var(--intro-accent-rgb, 212 169 107) / 0.24);
}
.public-world-intro-side{
  display:flex;
  flex-direction:column;
  gap:16px;
  min-height:460px;
}
.public-world-intro-copy h3{
  margin:0;
  font-size:26px;
  line-height:1.06;
  color:var(--public-text);
}
.public-world-intro-copy p{
  margin:10px 0 0;
  color:var(--public-muted);
  line-height:1.62;
}
.public-world-intro-identity{
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid rgba(184,146,123,0.16);
  background:rgba(255,255,255,0.025);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-identity-head{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.public-world-intro-identity-head strong{
  font-size:28px;
  line-height:1.02;
  color:var(--public-text);
}
.public-world-intro-identity-sub{
  display:flex;
  align-items:center;
  gap:9px;
  flex-wrap:wrap;
  color:var(--public-muted);
}
.public-world-intro-identity-sub img{width:18px;height:18px;object-fit:contain;}
.public-world-intro-racebadge{display:block;height:28px;width:auto;max-width:160px;filter:drop-shadow(0 8px 14px rgba(0,0,0,0.24));}
.public-world-intro-stats{
  display:grid;
  gap:10px;
  grid-template-columns:repeat(2, minmax(0,1fr));
}
.public-world-intro-stat{
  padding:12px 14px;
  border:1px solid rgba(184,146,123,0.16);
  background:linear-gradient(180deg, rgba(20,13,20,0.90), rgba(8,5,11,0.98));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-stat span{
  display:block;
  margin-bottom:6px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(233,213,195,0.62);
}
.public-world-intro-stat strong{
  display:block;
  font-size:22px;
  line-height:1;
  color:var(--public-text);
}
.public-world-intro-beats{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.public-world-intro-beat{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px 14px;
  border:1px solid rgba(184,146,123,0.16);
  background:rgba(255,255,255,0.025);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-beat-index{
  flex:0 0 34px;
  min-height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(var(--intro-accent-rgb, 212 169 107) / 0.24);
  background:rgba(var(--intro-accent-rgb, 212 169 107) / 0.12);
  color:var(--public-text);
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
}
.public-world-intro-beat-copy strong{display:block;margin-bottom:4px;color:var(--public-text);}
.public-world-intro-beat-copy span{display:block;color:var(--public-muted);line-height:1.55;}
.public-world-intro-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-top:auto;
}
.public-world-intro-actions .btn{min-width:164px;}
.public-world-intro-actions .btn.primary[disabled]{opacity:.64;filter:saturate(.7);cursor:progress;}
.public-world-intro-note{
  margin:2px 0 0;
  color:var(--public-muted);
  font-size:13px;
  line-height:1.55;
}
.public-world-intro-video{
  width:100%;
  height:100%;
  display:block;
  background:#000;
}
.public-world-intro-video-wrap{min-height:460px;}

@media (max-width: 980px){
  .public-world-intro-grid{grid-template-columns:minmax(0,1fr);}
  .public-world-intro-side{min-height:0;}
}
@media (max-width: 760px){
  .public-world-intro-stagecard{min-height:0;}
  .public-world-intro-visual{min-height:240px;padding:32px 18px 116px;}
  .public-world-intro-logo{width:min(48%, 150px);}
  .public-world-intro-avatar{width:min(48%, 180px);}
  .public-world-intro-actions{flex-direction:column-reverse;align-items:stretch;}
  .public-world-intro-actions .btn{width:100%;}
}

.public-world-intro-frame{
  grid-template-columns:minmax(300px, 1.02fr) minmax(320px, .98fr);
  min-height:420px;
}
.public-world-intro-visual{
  position:relative;
  min-height:320px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:38px 24px 108px;
  background:
    linear-gradient(180deg, rgba(7,10,18,0.34), rgba(7,5,11,0.78)),
    var(--public-world-intro-bg, url("../img/ui/public/login_bg.jpg")) center center / cover no-repeat;
}
.public-world-intro-visual::after{
  content:'';
  position:absolute;
  left:50%;
  bottom:20px;
  width:min(58%, 280px);
  height:24px;
  transform:translateX(-50%);
  border-radius:999px;
  background:radial-gradient(circle at 50% 50%, rgba(142,194,255,0.26) 0%, rgba(0,0,0,0) 72%);
  filter:blur(8px);
}
.public-world-intro-visual-glow{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 46%, rgba(142,194,255,0.18), rgba(0,0,0,0) 44%);
  pointer-events:none;
}
.public-world-intro-logo-wrap{
  position:absolute;
  left:50%;
  top:42px;
  transform:translateX(-50%);
  pointer-events:none;
}
.public-world-intro-logo-wrap img{
  width:min(36vw, 170px);
  height:auto;
  opacity:.82;
  filter:drop-shadow(0 14px 28px rgba(0,0,0,0.44));
}
.public-world-intro-hero-wrap{
  position:relative;
  z-index:2;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  width:min(48%, 220px);
}
.public-world-intro-hero{
  width:100%;
  height:auto;
  object-fit:contain;
  image-rendering:pixelated;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,0.42));
}
.public-world-intro-nameplate{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:12px 14px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(20,13,20,0.90), rgba(8,5,11,0.98));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-nameplate-label{
  color:rgba(233,213,195,0.62);
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.public-world-intro-nameplate strong{
  font-size:24px;
  line-height:1.04;
  color:var(--public-text);
}
.public-world-intro-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
  padding:24px 22px 24px 0;
}
.public-world-intro-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.public-world-intro-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:36px;
  padding:8px 12px;
  border:1px solid rgba(184,146,123,0.18);
  background:rgba(10,6,12,0.82);
  color:var(--public-text);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-badge img{
  width:18px;
  height:18px;
  object-fit:contain;
}
.public-world-intro-race-line{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:42px;
  padding:10px 12px;
  border:1px solid rgba(184,146,123,0.16);
  background:linear-gradient(180deg, rgba(20,13,20,0.90), rgba(8,5,11,0.98));
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}
.public-world-intro-race-line-icon{
  width:18px;
  height:18px;
  object-fit:contain;
}
.public-world-intro-race-line-label{
  color:rgba(233,213,195,0.66);
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  white-space:nowrap;
}
.public-world-intro-race-line-badge{
  display:block;
  height:18px;
  width:auto;
  max-width:160px;
  margin-left:auto;
  filter:drop-shadow(0 8px 14px rgba(0,0,0,0.24));
}
.public-world-intro-sequence{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.public-world-intro-progress.is-legacy-track{
  position:relative;
  overflow:hidden;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,0.06);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.35);
}
.public-world-intro-progress.is-legacy-track > span{
  position:absolute;
  inset:0 auto 0 0;
  width:0;
  border-radius:inherit;
  background:linear-gradient(90deg, rgba(142,194,255,0.32), rgba(244,236,231,0.74));
  transition:width 2.6s cubic-bezier(.22,1,.36,1);
}
.public-world-intro-lines{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.public-world-intro-lines li{
  position:relative;
  margin:0;
  padding:11px 12px 11px 30px;
  border:1px solid rgba(184,146,123,0.14);
  background:linear-gradient(180deg, rgba(18,12,19,0.82), rgba(8,5,11,0.96));
  color:var(--public-muted);
  line-height:1.58;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
  opacity:.44;
  transform:translateX(8px);
  transition:opacity .28s ease, transform .34s ease, border-color .34s ease, color .34s ease;
}
.public-world-intro-lines li::before{
  content:'';
  position:absolute;
  left:12px;
  top:50%;
  width:8px;
  height:8px;
  margin-top:-4px;
  border-radius:50%;
  background:rgba(142,194,255,0.34);
}
.public-world-intro-lines li strong{color:var(--public-text);}
.public-world-intro-lines li.is-visible{
  opacity:1;
  transform:none;
  color:var(--public-text);
  border-color:rgba(184,146,123,0.22);
}
.public-world-intro-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.public-world-intro-form{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  flex-wrap:wrap;
}
.public-world-intro-form .btn{min-width:180px;}
.public-world-intro-form [data-intro-enter-btn].is-intro-ready{
  box-shadow:0 0 0 1px rgba(142,194,255,0.18), 0 10px 22px rgba(0,0,0,0.24), 0 0 18px rgba(142,194,255,0.12);
}
@media (max-width: 980px){
  .public-world-intro-frame{grid-template-columns:minmax(0,1fr);min-height:0;}
  .public-world-intro-copy{padding:0 18px 20px;}
}
@media (max-width: 760px){
  .public-world-intro-visual{min-height:240px;padding:32px 18px 108px;}
  .public-world-intro-logo-wrap img{width:min(42vw, 140px);}
  .public-world-intro-hero-wrap{width:min(54%, 180px);}
  .public-world-intro-race-line{align-items:flex-start;flex-wrap:wrap;}
  .public-world-intro-race-line-badge{margin-left:0;}
  .public-world-intro-actions{align-items:stretch;}
  .public-world-intro-form{width:100%;justify-content:stretch;}
  .public-world-intro-form .btn{width:100%;min-width:0;}
}

/* Intro page: full-width stage cleanup + action alignment (2026-03-25) */
.public-world-intro-grid{
  grid-template-columns:minmax(0,1fr);
}

.public-world-intro-stagecard{
  min-height:560px;
}

.public-world-intro-video-wrap{
  min-height:420px;
}

.public-world-intro-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:420px;
  border:1px solid rgba(184,146,123,0.16);
  background:linear-gradient(180deg, rgba(2,2,4,0.98), rgba(0,0,0,1));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.02);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}

.public-world-intro-placeholder span{
  display:block;
  font-size:clamp(34px, 5vw, 68px);
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(255,244,233,0.92);
}

.public-world-intro-visual{
  min-height:420px;
  padding:44px 34px 122px;
}

.public-world-intro-stageidentity{
  position:absolute;
  left:24px;
  top:78px;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:6px;
  max-width:min(360px, calc(100% - 48px));
  padding:12px 14px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(18,12,18,0.86), rgba(9,6,12,0.94));
  box-shadow:0 10px 24px rgba(0,0,0,0.24);
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px);
}

.public-world-intro-stageidentity strong{
  display:block;
  margin:0;
  font-size:clamp(24px, 2.6vw, 34px);
  line-height:1.02;
  color:var(--public-text);
  overflow-wrap:anywhere;
}

.public-world-intro-stageidentity span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:rgba(233,213,195,0.82);
  font-size:15px;
  font-weight:800;
  line-height:1.2;
}

.public-world-intro-stageidentity span img{
  display:block;
  width:18px;
  height:18px;
  object-fit:contain;
}

.public-world-intro-charmeta{
  justify-content:center;
}

.public-world-intro-chip--badge{
  padding-inline:10px;
}

.public-world-intro-chip--badge img{
  width:auto;
  max-width:132px;
  height:22px;
}

.public-world-intro-progress{
  display:flex;
  flex-direction:column;
  position:relative;
  overflow:visible;
  height:auto;
  gap:12px;
  padding:16px 20px 18px;
  border-top:1px solid rgba(184,146,123,0.14);
  border-radius:0 0 14px 14px;
  background:linear-gradient(180deg, rgba(10,6,12,0.78), rgba(6,4,9,0.94));
  box-shadow:none;
}

.public-world-intro-progress-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.public-world-intro-progress-head span,
.public-world-intro-progress-head strong{
  position:static;
  inset:auto;
  width:auto;
  border-radius:0;
  background:none;
  transition:none;
}

.public-world-intro-progress-track{
  position:relative;
  overflow:hidden;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(184,146,123,0.16);
  background:rgba(255,255,255,0.05);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.35);
}

.public-world-intro-progress-track > span{
  position:absolute;
  inset:0 auto 0 0;
  display:block;
  width:0%;
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg, rgba(var(--intro-accent-rgb, 212 169 107) / 0.96), rgba(188,221,255,0.94));
  box-shadow:0 0 18px rgba(var(--intro-accent-rgb, 212 169 107) / 0.24);
  transition:width .26s ease;
}

.public-world-intro-status{
  margin:0;
  color:var(--public-muted);
  line-height:1.58;
}

.public-world-intro-actions--under-stage{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:12px;
  align-items:stretch;
  margin-top:0;
}

.public-world-intro-actions--under-stage > *{
  min-width:0;
}

.public-world-intro-actions--under-stage .btn,
.public-world-intro-actions--under-stage .public-world-intro-actions-form,
.public-world-intro-actions--under-stage .public-world-intro-actions-form .btn{
  width:100%;
}

.public-world-intro-actions--replay{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

.public-world-intro-actions--replay > .btn:first-child{
  margin-right:auto;
}

.public-world-intro-actions--replay > .btn:last-child{
  margin-left:auto;
}

.public-world-intro-actions--replay .btn{
  width:auto;
  min-width:220px;
}

@media (max-width: 900px){
  .public-world-intro-stagecard{
    min-height:500px;
  }

  .public-world-intro-visual{
    min-height:360px;
    padding:40px 24px 118px;
  }

  .public-world-intro-placeholder{
    min-height:360px;
  }

  .public-world-intro-stageidentity{
    left:20px;
    right:20px;
    max-width:none;
  }
}

@media (max-width: 760px){
  .public-world-intro-stagecard{
    min-height:0;
  }

  .public-world-intro-visual{
    min-height:250px;
    padding:84px 18px 118px;
  }

  .public-world-intro-placeholder{
    min-height:250px;
  }

  .public-world-intro-placeholder span{
    font-size:30px;
    letter-spacing:.18em;
  }

  .public-world-intro-stageidentity{
    top:72px;
    left:18px;
    right:18px;
    padding:10px 12px;
  }

  .public-world-intro-stageidentity strong{
    font-size:24px;
  }

  .public-world-intro-stageidentity span{
    font-size:14px;
  }

  .public-world-intro-actions--under-stage{
    grid-template-columns:minmax(0,1fr);
  }

  .public-world-intro-actions--replay{
    flex-direction:column;
    align-items:stretch;
  }

  .public-world-intro-actions--replay .btn{
    width:100%;
    min-width:0;
  }
}

.public-intro-library-grid{
  display:grid;
  gap:18px;
  grid-template-columns:minmax(0, 1.08fr) minmax(280px, .92fr);
  align-items:start;
}

.public-intro-library-main,
.public-intro-library-card,
.public-intro-library-sidehint{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(14,9,16,0.96), rgba(8,5,11,0.99));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.02), 0 16px 28px rgba(0,0,0,0.26);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}

.public-intro-library-main{
  display:grid;
  grid-template-columns:minmax(240px, .94fr) minmax(220px, .78fr);
  gap:16px;
  padding:18px;
  align-items:stretch;
}

.public-intro-library-previewcard{
  min-width:0;
}

.public-intro-library-placeholder{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:248px;
  border:1px solid rgba(184,146,123,0.16);
  background:linear-gradient(180deg, rgba(2,2,4,0.98), rgba(0,0,0,1));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.02);
  clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
}

.public-intro-library-placeholder span{
  display:block;
  font-size:clamp(26px, 3vw, 42px);
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,244,233,0.92);
}

.public-intro-library-watch{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:10px;
  min-width:0;
}

.public-intro-library-watch h3{
  margin:0;
  font-size:30px;
  line-height:1.06;
  color:var(--public-text);
}

.public-intro-library-watch-subtitle{
  margin:0;
  color:rgba(233,213,195,0.84);
  font-size:15px;
  font-weight:800;
  line-height:1.45;
}

.public-intro-library-watch p{
  margin:0;
  color:var(--public-muted);
  line-height:1.62;
}

.public-intro-library-status{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  min-height:36px;
  padding:0 14px;
  border:1px solid rgba(184,146,123,0.18);
  background:linear-gradient(180deg, rgba(54,36,42,0.92), rgba(18,11,18,0.98));
  font-size:11px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,244,233,.92);
}

.public-intro-library-status.is-unlocked{
  border-color:rgb(var(--intro-accent-rgb, 212 169 107) / 0.28);
  background:linear-gradient(180deg, rgb(var(--intro-accent-rgb, 212 169 107) / 0.16), rgba(18,11,18,0.98));
}

.public-intro-library-status.is-locked{
  opacity:.8;
}

.public-intro-library-note{
  margin:0;
  color:var(--public-muted);
  line-height:1.62;
}

.public-intro-library-actions{
  display:flex;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
  margin-top:4px;
}

.public-intro-library-actions .btn.is-disabled{
  pointer-events:none;
  opacity:.58;
}

.public-intro-library-list{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}

.public-intro-library-card{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:14px 14px 15px;
  text-decoration:none;
  color:inherit;
  transition:border-color .16s ease, transform .16s ease, box-shadow .16s ease, background .16s ease;
}

.public-intro-library-card:hover{
  border-color:rgba(206,168,143,0.34);
  transform:translateY(-1px);
}

.public-intro-library-card.is-selected{
  border-color:rgb(var(--intro-accent-rgb, 212 169 107) / 0.28);
  box-shadow:inset 0 0 0 1px rgb(var(--intro-accent-rgb, 212 169 107) / 0.08), 0 16px 28px rgba(0,0,0,0.28);
}

.public-intro-library-card.is-locked{
  opacity:.74;
}

.public-intro-library-cardgroup{
  display:block;
  font-size:10px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(233,213,195,0.56);
}

.public-intro-library-card strong{
  display:block;
  font-size:18px;
  line-height:1.16;
  color:var(--public-text);
}

.public-intro-library-card span:last-of-type{
  color:var(--public-muted);
  line-height:1.5;
}

.public-intro-library-card em{
  display:inline-block;
  margin-top:4px;
  font-style:normal;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,244,233,.82);
}

.public-intro-library-sidehint{
  display:flex;
  flex-direction:column;
  gap:7px;
  padding:14px;
}

.public-intro-library-sidehint strong{
  display:block;
  font-size:16px;
  line-height:1.2;
  color:var(--public-text);
}

.public-intro-library-sidehint p{
  margin:0;
  color:var(--public-muted);
  line-height:1.6;
}

.public-intro-library-footer{
  display:flex;
  justify-content:flex-end;
  margin-top:16px;
}

@media (max-width: 1140px){
  .public-intro-library-main{
    grid-template-columns:minmax(0,1fr);
  }
}

@media (max-width: 980px){
  .public-intro-library-grid{
    grid-template-columns:minmax(0,1fr);
  }
}
@media (max-width: 760px){
  .public-intro-library-main{padding:14px;}
  .public-intro-library-placeholder{min-height:220px;}
  .public-intro-library-placeholder span{font-size:24px;letter-spacing:.18em;}
  .public-intro-library-watch h3{font-size:26px;}
  .public-intro-library-actions{align-items:stretch;}
  .public-intro-library-actions .btn{width:100%;}
  .public-intro-library-footer{justify-content:stretch;}
  .public-intro-library-footer .btn{width:100%;}
}


.public-footer-band{
  width:min(1160px, 100%);
  margin-inline:auto;
  box-sizing:border-box;
  padding:0 24px;
}
.public-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  padding:8px 0 2px;
}
.public-footer--outside{
  padding:0;
}
.public-footer__meta{
  color:var(--public-muted);
  font-size:13px;
  line-height:1.5;
}
.public-footer__links{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}
.public-footer__links a{
  color:var(--public-text);
  text-decoration:none;
  font-size:13px;
}
.public-footer__links a:hover,
.public-footer__links a:focus-visible{
  text-decoration:underline;
}
.public-legal-panel{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.public-legal-content{
  display:flex;
  flex-direction:column;
  gap:14px;
  color:var(--public-muted);
  line-height:1.72;
}
.public-legal-content p,
.public-legal-content ul{
  margin:0;
}
.public-legal-content ul{
  padding-left:22px;
}
.public-faq-pager{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-top:16px;
}
.public-faq-pager__meta{
  color:var(--public-muted);
  font-size:13px;
}
.public-faq-pager__actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.public-faq-pager__actions .btn[aria-disabled="true"]{
  pointer-events:none;
  opacity:.55;
}
@media (max-width: 720px){
  .public-footer-band{padding:0 12px;}
  .public-footer,
  .public-faq-pager{
    align-items:flex-start;
    flex-direction:column;
  }
}
