/* --- Roleen signup styles --- */
:root{
  --bg: #000000;
  --fg: #ffffff;
  --emerald: #10b981;
  --muted: rgba(255,255,255,0.08);
  --glass: rgba(255,255,255,0.03);
  --shadow: 0 10px 30px rgba(2,6,23,0.75);
  --radius: 12px;
  --panel-pad: 22px;
  font-family: "Russo One", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--fg);}

/* layout */
.page{display:flex;gap:20px;align-items:flex-start;justify-content:center;padding:36px;min-height:calc(100vh - 60px)}
.panel{background:linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));border-radius:var(--radius);padding:var(--panel-pad);box-shadow:var(--shadow);max-width:720px;flex:1;overflow:hidden}
.left-panel{min-width:420px}
.right-panel{width:320px}

/* header */
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.logo{font-size:28px;color:var(--emerald);letter-spacing:1px}
.tag{font-size:12px;color:rgba(255,255,255,0.6);text-transform:uppercase}

/* marquee */
.marquee-wrap{margin:10px 0;padding:8px;border-radius:10px;border:1px dashed rgba(255,255,255,0.04);background:linear-gradient(90deg, rgba(255,255,255,0.01), transparent)}
.marquee{display:block;white-space:nowrap;overflow:hidden;padding:6px 8px;font-size:14px;border-radius:8px;cursor:text}
.marquee[contenteditable="true"]{outline:none;border:1px dashed rgba(16,185,129,0.12);padding:10px}
.marquee-hint{margin-top:6px;color:rgba(255,255,255,0.45);font-size:12px}

/* buttons */
.controls{margin:14px 0 6px}
.btn{display:inline-block;padding:12px 16px;border-radius:10px;border:2px solid transparent;background:var(--glass);color:var(--fg);cursor:pointer;transition:all .18s ease;font-weight:700}
.btn:hover{transform:scale(1.06)}
.btn.primary{border-color:var(--emerald);background:linear-gradient(180deg, rgba(16,185,129,0.06), transparent)}
.btn.success{border-color:#06b6d4;background:linear-gradient(180deg, rgba(6,182,212,0.04), transparent)}

/* form */
.form-title{margin:10px 0 8px;font-size:20px}
.field{margin:12px 0;display:block}
.field-label{display:block;margin-bottom:6px;color:rgba(255,255,255,0.85);font-size:13px}
.input, .select, .textarea{
  width:100%;padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,0.05);
  background:transparent;color:var(--fg);font-family:"Russo One",inherit;font-size:14px;transition:transform .12s ease, box-shadow .12s ease;
  outline:none;
}
.select{appearance:none;padding-right:30px}
.textarea{min-height:92px;resize:vertical;padding:12px}

/* hover expansion */
.input:hover, .select:hover, .textarea:hover{transform:scale(1.02)}

/* typing shake and press shake */
@keyframes typeshake {
  0%{transform:translateX(0)}
  25%{transform:translateX(-4px)}
  50%{transform:translateX(3px)}
  75%{transform:translateX(-2px)}
  100%{transform:translateX(0)}
}
@keyframes pressShake {
  0%{transform:translateY(0)}
  25%{transform:translateY(-8px)}
  50%{transform:translateY(6px)}
  75%{transform:translateY(-3px)}
  100%{transform:translateY(0)}
}

/* focus styles: upward move on focus, up/down on submit (JS triggers pressShake) */
.input:focus, .textarea:focus, .select:focus{transform:translateY(-4px);box-shadow:0 12px 30px rgba(16,185,129,0.06);border-color:rgba(16,185,129,0.18)}

/* file + preview */
.file-field .file-input{display:block;margin-bottom:8px}
.frame-preview{width:140px;height:140px;border-radius:12px;border:1px solid rgba(255,255,255,0.04);overflow:hidden;display:flex;align-items:center;justify-content:center}
.frame-preview img{width:100%;height:100%;object-fit:cover}

/* avatar preview */
.avatar-wrap{display:flex;align-items:center;flex-direction:column;gap:12px}
.avatar-preview{position:relative}
.avatar-preview img{width:140px;height:140px;border-radius:50%;object-fit:cover;border:3px solid var(--emerald);display:block}
.avatar-tag{position:absolute;right:-6px;bottom:-6px;background:var(--emerald);color:#000;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}

/* badge card */
.badge-card{display:flex;gap:12px;align-items:center;margin-top:6px}
.badge-gif{width:48px;height:48px;object-fit:cover;border-radius:8px}
.badge-name{font-weight:700;color:var(--emerald)}

/* small text */
.small{font-size:12px;color:rgba(255,255,255,0.65)}

/* footer */
.site-footer{padding:12px;text-align:center;color:rgba(255,255,255,0.35);font-size:12px}

/* slide-in intro animations */
@keyframes slideFromLeft { from { transform: translateX(-40px); opacity: 0 } to { transform: translateX(0); opacity: 1 } }
@keyframes slideFromRight { from { transform: translateX(40px); opacity: 0 } to { transform: translateX(0); opacity: 1 } }
.left-panel{animation:slideFromLeft 700ms cubic-bezier(.2,.9,.2,1) both}
.right-panel{animation:slideFromRight 700ms cubic-bezier(.2,.9,.2,1) both}

/* marquee scroll (visual only) */
.marquee { animation: marquee-linear 10s linear infinite; }
@keyframes marquee-linear {
  0%{ transform: translateX(100%) }
  100%{ transform: translateX(-100%) }
}

/* responsive */
@media (max-width:900px){
  .page{flex-direction:column;padding:14px}
  .left-panel{min-width:auto}
  .right-panel{width:100%}
}
