
/* ── JAVIS Nav ──────────────────────────────────────────────────────────── */
.javis-nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 1.5rem;
  background: rgba(10,14,26,0.95);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.javis-nav__home {
  font-weight: 700;
  font-size: 1rem;
  color: #7c83fd;
  text-decoration: none;
  letter-spacing: 0.05em;
}
.javis-nav__links { display: flex; gap: 1.2rem; }
.javis-nav__links a {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  font-size: 0.85rem;
  transition: color 0.2s;
}
.javis-nav__links a:hover { color: #fff; }
.javis-nav__links a.active { color: #fff; font-weight: 600; }

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+KR:wght@300;400;700&family=Noto+Sans+KR:wght@300;400;500;700&display=swap');
:root{
  --gold:#c9a84c;--gold-l:#f0d080;--gold-d:#8b5e1a;
  --bg:#06030e;--card:rgba(255,255,255,0.04);
  --card2:rgba(255,255,255,0.06);
  --border:rgba(201,168,76,0.2);--border2:rgba(255,255,255,0.08);
  --text:rgba(232,224,208,0.92);--text-dim:rgba(232,224,208,0.42);
  --purple:rgba(120,60,220,.15);--blue:rgba(60,100,220,.12);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{width:100%;max-width:100%;overflow-x:hidden;}
body{font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;}
.bg-stars{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.bg-stars::before{content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 15% 40%,rgba(100,60,200,.2) 0%,transparent 55%),
    radial-gradient(ellipse at 85% 15%,rgba(60,30,140,.25) 0%,transparent 50%),
    radial-gradient(ellipse at 50% 95%,rgba(160,100,20,.15) 0%,transparent 45%),
    radial-gradient(ellipse at 30% 80%,rgba(80,40,180,.1) 0%,transparent 40%);}
.bg-stars::after{content:'';position:absolute;inset:0;background-image:
  radial-gradient(1px 1px at 8% 12%,rgba(255,255,255,.9) 0%,transparent 100%),
  radial-gradient(1.5px 1.5px at 38% 8%,rgba(255,255,220,.95) 0%,transparent 100%),
  radial-gradient(1px 1px at 52% 55%,rgba(255,255,255,.65) 0%,transparent 100%),
  radial-gradient(1.5px 1.5px at 83% 70%,rgba(255,255,255,.85) 0%,transparent 100%),
  radial-gradient(1px 1px at 22% 35%,rgba(255,255,220,.75) 0%,transparent 100%),
  radial-gradient(1px 1px at 67% 22%,rgba(255,255,220,.8) 0%,transparent 100%),
  radial-gradient(1px 1px at 12% 78%,rgba(255,255,255,.6) 0%,transparent 100%),
  radial-gradient(1px 1px at 91% 42%,rgba(255,255,220,.75) 0%,transparent 100%),
  radial-gradient(1.5px 1.5px at 58% 92%,rgba(255,255,220,.7) 0%,transparent 100%),
  radial-gradient(1px 1px at 75% 5%,rgba(255,255,255,.65) 0%,transparent 100%),
  radial-gradient(1px 1px at 44% 28%,rgba(255,255,255,.5) 0%,transparent 100%),
  radial-gradient(1px 1px at 3% 62%,rgba(255,255,220,.45) 0%,transparent 100%);}

/* ── 모달 ── */
.modal-wrap{position:fixed;inset:0;z-index:200;background:rgba(3,1,8,.96);display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-wrap.hide{display:none;}
.modal{
  background:linear-gradient(160deg,#0c0620,#160b2c 50%,#0c0620);
  border:1px solid rgba(201,168,76,.25);border-radius:28px;
  padding:36px 28px;max-width:400px;width:100%;
  box-shadow:0 0 100px rgba(100,60,200,.3),0 0 200px rgba(201,168,76,.05);
  text-align:center;
}
.modal .m-icon{font-size:60px;display:block;margin-bottom:14px;animation:float 3s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-6px) scale(1.05);}}
@keyframes pulse{0%,100%{transform:scale(1);}50%{transform:scale(1.08);}}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}
.modal h2{font-family:'Noto Serif KR',serif;font-size:21px;color:var(--gold-l);margin-bottom:8px;}
.modal .m-desc{font-size:13px;color:var(--text-dim);line-height:1.7;margin-bottom:26px;}
.field{margin-bottom:14px;text-align:left;}
.field label{display:block;font-size:11px;color:var(--gold);letter-spacing:.8px;margin-bottom:5px;text-transform:uppercase;}
.field input,.field select{
  width:100%;background:rgba(255,255,255,.05);
  border:1px solid rgba(201,168,76,.2);border-radius:12px;
  padding:12px 15px;color:var(--text);font-size:15px;
  font-family:'Noto Sans KR',sans-serif;outline:none;
  transition:border-color .25s,box-shadow .25s;
  -webkit-appearance:none;appearance:none;
}
.field input:focus,.field select:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,168,76,.1);
}
.field select option{background:#160b2c;}
.btn-go{
  width:100%;margin-top:6px;padding:14px;
  background:linear-gradient(135deg,var(--gold-d) 0%,var(--gold) 50%,var(--gold-d) 100%);
  background-size:200% 100%;border:none;border-radius:14px;
  color:#07040f;font-weight:700;font-size:15px;
  font-family:'Noto Sans KR',sans-serif;cursor:pointer;
  transition:background-position .4s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 24px rgba(201,168,76,.35);
}
.btn-go:hover{background-position:100% 0;box-shadow:0 6px 32px rgba(201,168,76,.5);}
.btn-go:active{transform:scale(.98);}

/* ── 카드 ── */
.card{
  background:linear-gradient(145deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.09);
  border-radius:22px;padding:20px;margin-bottom:14px;
  position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;inset:0;border-radius:22px;
  background:linear-gradient(145deg,rgba(201,168,76,.04),transparent 60%);
  pointer-events:none;
}
.sec-title{
  font-size:11px;color:var(--gold);letter-spacing:1.2px;
  margin-bottom:14px;text-transform:uppercase;
  display:flex;align-items:center;gap:6px;
}
.sec-title::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg,rgba(201,168,76,.3),transparent);
}

/* ── 반응형 ── */
@media(max-width:400px){
  .modal{padding:26px 16px;}
  .field input,.field select{font-size:14px;padding:10px 12px;}
  .card{padding:16px;}
}
#app{overflow:hidden;width:100%;}
.dm-bar-wrap{min-width:0;}
canvas{display:block;max-width:100%;}
