*{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#f5f5f7;
  --surface:#ffffff;
  --surface2:#f0f0f5;
  --border:#e2e2ea;
  --border2:#d0d0de;
  --accent:#5b4ff5;
  --accent2:#7b6fff;
  --accent-bg:#eeedfb;
  --green:#16a34a;
  --green-bg:#dcfce7;
  --red:#dc2626;
  --red-bg:#fee2e2;
  --yellow:#d97706;
  --yellow-bg:#fef3c7;
  --text:#111118;
  --text2:#52526e;
  --text3:#9898b8;
  --radius:14px;
  --radius-sm:8px;
  --shadow:0 1px 4px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.06);
  --shadow-sm:0 1px 3px rgba(0,0,0,.08);
}

body{
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  display:flex;
  height:100vh;
  overflow:hidden;
}

/* ── Phone frame ── */
#phone-frame{
  width:390px;min-width:390px;height:100vh;
  background:var(--surface);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:var(--shadow);
}

#status-bar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 20px 10px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
  background:var(--surface);
}
#status-bar .logo{font-weight:800;font-size:16px;color:var(--text);letter-spacing:-.4px}
#status-bar .logo span{color:var(--accent)}

/* Nav links — hidden, replaced by bottom nav */
.nav-links{display:none}

#screen{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--surface)}
#screen::-webkit-scrollbar{width:4px}
#screen::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}

/* ── Log panel ── */
#log-panel{
  flex:1;display:flex;flex-direction:column;overflow:hidden;
  background:var(--bg);
}
#log-header{
  padding:12px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;flex-shrink:0;
  background:var(--surface);
}
#log-header h2{font-size:12px;font-weight:600;color:var(--text2);letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}
#base-url{
  flex:1;background:var(--surface2);border:1px solid var(--border2);
  border-radius:var(--radius-sm);padding:6px 10px;color:var(--text);
  font-size:12px;font-family:'SF Mono',ui-monospace,monospace;
}
#base-url:focus{outline:none;border-color:var(--accent)}
#clear-log{
  background:none;border:1px solid var(--border2);color:var(--text2);
  font-size:12px;padding:5px 10px;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;
}
#clear-log:hover{color:var(--text);border-color:var(--border2);background:var(--surface2)}

#log-list{
  flex:1;overflow-y:auto;padding:10px 12px;
  display:flex;flex-direction:column;gap:8px;
}
#log-list::-webkit-scrollbar{width:4px}
#log-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}

.empty-log{color:var(--text3);font-size:13px;padding:24px;text-align:center}

.log-entry{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);overflow:hidden;
}
.log-entry-header{
  display:flex;align-items:center;gap:8px;padding:8px 12px;
  cursor:pointer;user-select:none;
}
.log-entry-header:hover{background:var(--surface2)}
.log-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase}
.badge-ok{background:#dcfce7;color:#16a34a}
.badge-err{background:#fee2e2;color:#dc2626}
.badge-pending{background:#fef3c7;color:#d97706}
.log-method{font-size:10px;font-weight:700;color:var(--text2)}
.log-path{font-size:12px;color:var(--text);flex:1;font-family:'SF Mono',ui-monospace,monospace}
.log-ms{font-size:11px;color:var(--text3);margin-left:auto}
.log-body{
  display:none;border-top:1px solid var(--border);
  padding:10px 12px;font-family:'SF Mono',ui-monospace,monospace;
  font-size:11.5px;line-height:1.7;white-space:pre-wrap;word-break:break-all;
  max-height:300px;overflow-y:auto;background:#fafafa;
}
.log-body.open{display:block}
.log-comment{color:var(--text3)}
.jk{color:#6366f1}.js{color:#16a34a}.jn{color:#d97706}.jb{color:#db2777}.jl{color:#9898b8}

/* ── Shared primitives ── */
.screen-pad{padding:24px 20px}

h2.screen-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px}
p.screen-sub{font-size:14px;color:var(--text2);line-height:1.5;margin-bottom:24px}

.field{margin-bottom:16px}
.field label{
  display:block;font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:.7px;color:var(--text3);margin-bottom:6px;
}
.field input,.field select,.field textarea{
  width:100%;background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:var(--radius-sm);padding:11px 13px;color:var(--text);
  font-size:14px;transition:border-color .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#fff}
.field input::placeholder,.field textarea::placeholder{color:var(--text3)}
.field select option{background:#fff}
.field textarea{resize:vertical;min-height:80px;font-family:inherit;line-height:1.5}
.field input[type="file"]{
  background:none;border:2px dashed var(--border2);padding:20px;
  text-align:center;color:var(--text2);cursor:pointer;
}
.field input[type="file"]:hover{border-color:var(--accent);color:var(--accent)}

.btn{
  width:100%;padding:13px;border:none;border-radius:var(--radius-sm);
  font-size:15px;font-weight:600;cursor:pointer;
  transition:opacity .15s,transform .1s;
}
.btn:active{transform:scale(.98)}
.btn:disabled{opacity:.4;cursor:default;transform:none}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--accent2)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1.5px solid #fca5a5}
.btn-danger:hover:not(:disabled){background:#fecaca}
.btn-ghost{background:var(--surface2);color:var(--text2);border:1.5px solid var(--border2)}
.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border2);background:var(--border)}

.btn-sm{
  padding:7px 14px;font-size:12px;border-radius:6px;
  border:1.5px solid var(--border2);cursor:pointer;font-weight:600;
  background:var(--surface2);color:var(--text2);transition:all .15s;
}
.btn-sm:hover{color:var(--text);background:var(--border)}
.btn-sm-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-sm-primary:hover{background:var(--accent2);border-color:var(--accent2)}
.btn-sm-danger{background:var(--red-bg);color:var(--red);border-color:#fca5a5}

.divider{
  display:flex;align-items:center;gap:12px;margin:20px 0;
  color:var(--text3);font-size:12px;
}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}

.alert{padding:11px 14px;border-radius:var(--radius-sm);font-size:13px;line-height:1.5;margin-bottom:14px}
.alert-ok{background:var(--green-bg);border:1px solid #86efac;color:var(--green)}
.alert-err{background:var(--red-bg);border:1px solid #fca5a5;color:var(--red)}
.alert-info{background:var(--accent-bg);border:1px solid #c7d2fe;color:var(--accent)}
.alert-warn{background:var(--yellow-bg);border:1px solid #fcd34d;color:var(--yellow)}

/* OTP grid */
.otp-grid{display:flex;gap:8px;justify-content:center;margin-bottom:20px}
.otp-grid input{
  width:52px;height:60px;text-align:center;font-size:24px;font-weight:700;
  background:#fff;border:2px solid var(--border2);border-radius:var(--radius-sm);color:var(--text);
}
.otp-grid input:focus{outline:none;border-color:var(--accent);background:#fff}

/* Profile card */
.profile-card{
  background:linear-gradient(135deg,var(--accent-bg),#f0efff);
  border:1px solid #ddd9ff;border-radius:var(--radius);
  padding:24px;margin-bottom:20px;text-align:center;
}
.avatar{
  width:80px;height:80px;border-radius:50%;background:var(--surface2);
  border:2px solid var(--border2);margin:0 auto 12px;
  display:flex;align-items:center;justify-content:center;font-size:28px;
  overflow:hidden;cursor:pointer;position:relative;
}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.avatar-overlay{
  position:absolute;inset:0;background:rgba(0,0,0,.35);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  opacity:0;transition:opacity .2s;
}
.avatar:hover .avatar-overlay{opacity:1}
.profile-name{font-size:20px;font-weight:700;margin-bottom:4px;color:var(--text)}
.profile-code{
  font-size:12px;color:var(--accent);background:#fff;
  display:inline-block;padding:3px 10px;border-radius:20px;margin-bottom:8px;
  font-family:'SF Mono',ui-monospace,monospace;border:1px solid var(--accent-bg);
}
.profile-about{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:10px}
.profile-plan{
  display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;padding:3px 10px;border-radius:20px;
  background:var(--accent-bg);color:var(--accent);border:1px solid #ddd9ff;
}

.tags-row{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:10px}
.tag-chip{
  background:#fff;border:1px solid var(--border2);border-radius:20px;
  padding:4px 10px;font-size:11px;color:var(--text2);
}
.tag-chip.company{border-color:#ddd9ff;color:var(--accent);background:var(--accent-bg)}

.icons-grid{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:12px}
.icon-chip{
  background:#fff;border:1px solid var(--border2);border-radius:var(--radius-sm);
  padding:6px 12px;font-size:12px;color:var(--text2);display:flex;align-items:center;gap:6px;
}
.icon-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.icon-chip .dot.hidden{background:var(--text3)}

/* Session card */
.session-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:12px;
}
.session-info{flex:1;min-width:0}
.session-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.session-meta{font-size:11px;color:var(--text2);margin-top:2px}

/* Bottom nav */
#bottom-nav{
  flex-shrink:0;
  border-top:1px solid var(--border);background:var(--surface);
  padding-bottom:env(safe-area-inset-bottom,0px);
}
.nav-tabs{display:flex;overflow-x:auto;scrollbar-width:none}
.nav-tabs::-webkit-scrollbar{display:none}
.nav-tab{
  flex:0 0 auto;min-width:60px;padding:10px 6px 8px;text-align:center;cursor:pointer;
  border:none;background:none;color:var(--text3);font-size:10px;
  transition:color .15s;display:flex;flex-direction:column;align-items:center;gap:3px;
  text-decoration:none;
}
.nav-tab .icon{font-size:20px;line-height:1}
.nav-tab.active{color:var(--accent)}
.nav-tab:hover{color:var(--text2)}

/* Toggle */
.toggle-row{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);gap:12px}
.toggle-row:last-child{border-bottom:none}
.toggle-label{flex:1;font-size:14px;color:var(--text)}
.toggle{
  position:relative;width:40px;height:24px;
  background:var(--border2);border-radius:12px;cursor:pointer;transition:background .2s;
}
.toggle.on{background:var(--accent)}
.toggle::after{
  content:'';position:absolute;width:16px;height:16px;background:#fff;
  border-radius:50%;top:4px;left:4px;transition:transform .2s;
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.toggle.on::after{transform:translateX(16px)}

/* Icon builder */
.icon-builder-row{
  display:flex;align-items:center;gap:8px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:6px;
}
.icon-builder-row select,.icon-builder-row input{
  background:#fff;border:1px solid var(--border2);
  border-radius:6px;padding:6px 8px;color:var(--text);font-size:13px;
}
.icon-builder-row select:focus,.icon-builder-row input:focus{outline:none;border-color:var(--accent)}
.icon-builder-row input{flex:1}
.icon-remove{
  background:none;border:none;color:var(--text3);font-size:18px;
  cursor:pointer;padding:2px 4px;border-radius:4px;line-height:1;
}
.icon-remove:hover{color:var(--red);background:var(--red-bg)}

/* Plan cards */
.plan-card{
  background:#fff;border:2px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:12px;cursor:pointer;transition:all .15s;
}
.plan-card:hover{border-color:var(--accent-bg);box-shadow:var(--shadow-sm)}
.plan-card.selected{border-color:var(--accent);background:var(--accent-bg)}
.plan-card.current-plan{border-color:var(--green);background:var(--green-bg)}
.plan-name{font-size:16px;font-weight:700;color:var(--text)}
.plan-price{font-size:24px;font-weight:800;color:var(--accent);margin:4px 0}
.plan-price span{font-size:13px;font-weight:400;color:var(--text2)}
.plan-features{font-size:12px;color:var(--text2);line-height:1.8;margin-top:8px}

/* Public profile */
.public-card{
  background:#fff;border:1.5px solid var(--border2);
  border-radius:var(--radius);padding:24px;text-align:center;
}

/* Danger zone */
.danger-zone{
  border:1.5px solid #fca5a5;border-radius:var(--radius-sm);padding:16px;
}
.danger-title{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.8px;color:var(--red);margin-bottom:10px;
}

/* ── Extra shared pieces for multi-page UI ── */

/* section label used inside phone frame */
.section-label{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.8px;color:var(--text3);margin-bottom:10px;
}

/* plan cards inside phone frame (stacked, not grid) */
.plan-card{
  background:var(--surface2);border:1.5px solid var(--border2);
  border-radius:var(--radius-sm);padding:14px;margin-bottom:10px;
}
.plan-card:hover{border-color:var(--accent-bg)}
.plan-card-current{border-color:var(--green);background:var(--green-bg)}
.plan-name{font-size:14px;font-weight:700;color:var(--text)}
.plan-price{font-size:18px;font-weight:800;color:var(--accent)}
.plan-features{list-style:none;margin:6px 0 10px}
.plan-features li{font-size:12px;color:var(--text2);padding-left:14px;position:relative;margin-bottom:2px}
.plan-features li::before{content:'✓';position:absolute;left:0;color:var(--green);font-weight:700}

/* hidden utility */
.hidden{display:none!important}

/* lookup result */
#lookup-result.hidden{display:none}


