/* ============================================================
   COSMIC BYTE — Configurator Portal · Dark Brand Theme
   Tokens mirror cosmicbyte-configurator.html so the portal and
   the device UI are visually continuous.
   ============================================================ */
:root{
  --bg:#0a0e13;
  --panel:#101820;
  --panel-2:#15202b;
  --panel-3:#1b2733;
  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.12);
  --accent:#FF9E1B;          /* Pantone 1375C */
  --accent-2:#ffb849;
  --accent-deep:#cc7a14;
  --text:#e9eef4;
  --muted:#8593a3;
  --muted-2:#5d6b7a;
  --ok:#2bb673;
  --err:#e5484d;
  --disp:"Bricolage Grotesque",sans-serif;
  --body:"Sora",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);color:var(--text);font-family:var(--body);
  min-height:100vh;-webkit-font-smoothing:antialiased;position:relative;overflow-x:hidden;
  /* ATMOSPHERE — an amber energy core burning top-right, cool cosmic depth below */
  background-image:
    radial-gradient(1250px 860px at 88% -14%, rgba(255,158,27,.28), transparent 58%),
    radial-gradient(560px 560px at 88% -6%,  rgba(255,196,90,.20), transparent 60%),
    radial-gradient(960px 640px at 4% -8%,   rgba(255,158,27,.10), transparent 56%),
    radial-gradient(1400px 1050px at 50% 130%, rgba(38,108,205,.12), transparent 64%),
    radial-gradient(760px 760px at 10% 98%,  rgba(255,158,27,.05), transparent 62%);
  background-attachment:fixed;
}
/* STRUCTURE — orbital rings radiating from the core (the "Orbit"), HUD grid + energy streaks */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    repeating-radial-gradient(circle at 88% -2%, transparent 0 116px, rgba(255,158,27,.075) 116px 117px, transparent 117px 244px),
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    repeating-linear-gradient(122deg, transparent 0 76px, rgba(255,158,27,.055) 76px 77px, transparent 77px 172px);
  background-size:auto, 52px 52px, 52px 52px, auto;
  -webkit-mask-image:radial-gradient(155% 135% at 82% -6%, #000 0%, rgba(0,0,0,.55) 50%, transparent 88%);
          mask-image:radial-gradient(155% 135% at 82% -6%, #000 0%, rgba(0,0,0,.55) 50%, transparent 88%);
}
/* TEXTURE — scattered stars, focusing vignette, fine scanlines */
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    radial-gradient(1.6px 1.6px at 13% 17%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(1.4px 1.4px at 79% 29%, rgba(255,255,255,.42), transparent 60%),
    radial-gradient(1.2px 1.2px at 33% 61%, rgba(255,255,255,.40), transparent 60%),
    radial-gradient(1.3px 1.3px at 63% 77%, rgba(255,212,150,.50), transparent 60%),
    radial-gradient(1.5px 1.5px at 91% 63%, rgba(255,255,255,.36), transparent 60%),
    radial-gradient(1.1px 1.1px at 47% 11%, rgba(255,255,255,.34), transparent 60%),
    radial-gradient(1.2px 1.2px at 24% 88%, rgba(255,255,255,.30), transparent 60%),
    radial-gradient(120% 120% at 50% 38%, transparent 56%, rgba(0,0,0,.48) 100%),
    repeating-linear-gradient(0deg, rgba(255,255,255,.013) 0 1px, transparent 1px 3px);
}
@media (prefers-reduced-motion: no-preference){
  body::before{animation:cbBreath 18s ease-in-out infinite}
  body::after{animation:cbTwinkle 7s ease-in-out infinite}
}
@keyframes cbBreath{0%,100%{opacity:1}50%{opacity:.68}}
@keyframes cbTwinkle{0%,100%{opacity:1}50%{opacity:.82}}
/* keep all content above the atmosphere */
#screen-home,.cb-center,.cb-overlay,.cb-toast{position:relative;z-index:1}
a{color:inherit}
.mono{font-family:var(--mono);letter-spacing:.04em}
.eyebrow{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.muted{color:var(--muted)}
.hidden{display:none !important}

/* layout */
.cb-wrap{max-width:1080px;margin:0 auto;padding:26px 22px 60px}
.cb-center{min-height:100vh;display:grid;place-items:center;padding:24px}

/* brand */
.cb-brand{display:flex;align-items:center;gap:12px}
.cb-logo{width:40px;height:40px;flex:none;background:url(cb-logo.png) center/contain no-repeat;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}
.cb-brand-name{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:-.01em;text-transform:uppercase;color:#eef2f7}
.cb-brand-name b{color:inherit;font-weight:700}
.cb-wordmark{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);
  border:1px solid rgba(255,158,27,.4);border-radius:100px;padding:4px 9px;align-self:center}

/* topbar */
.cb-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:34px}
.cb-top-actions{display:flex;align-items:center;gap:10px}

/* cards / panels */
.cb-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:18px;padding:26px}
.cb-auth{width:min(420px,92vw)}
.cb-title{font-family:var(--disp);font-weight:800;font-size:30px;letter-spacing:-.02em;margin:14px 0 6px}
.cb-sub{color:var(--muted);font-size:14px;line-height:1.55;margin:0 0 22px}

/* inputs */
.cb-field{margin-bottom:14px}
.cb-label{display:block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:7px}
.cb-input{width:100%;background:var(--bg);border:1px solid var(--line-2);border-radius:11px;color:var(--text);
  font-family:var(--body);font-size:15px;padding:13px 14px;outline:none;transition:.15s}
.cb-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,158,27,.14)}
.cb-input::placeholder{color:var(--muted-2)}

/* OTP boxes */
.cb-otp{display:flex;gap:9px;justify-content:space-between}
.cb-otp input{width:100%;aspect-ratio:1/1;text-align:center;font-family:var(--mono);font-weight:700;font-size:22px;
  background:var(--bg);border:1px solid var(--line-2);border-radius:11px;color:var(--text);outline:none;transition:.15s}
.cb-otp input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,158,27,.14)}

/* buttons */
.cb-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;
  font-family:var(--mono);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:12px;
  background:var(--accent);color:#0a0e13;border:1px solid var(--accent);border-radius:100px;padding:14px 22px;cursor:pointer;transition:.16s}
.cb-btn:hover{background:var(--accent-2);border-color:var(--accent-2);transform:translateY(-1px);box-shadow:0 12px 30px -10px rgba(255,158,27,.55)}
.cb-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.cb-btn.ghost{background:transparent;color:var(--text);border-color:var(--line-2)}
.cb-btn.ghost:hover{background:var(--panel-3);border-color:var(--accent);box-shadow:none;transform:none}
.cb-btn.sm{width:auto;padding:9px 16px;font-size:11px}
.cb-link{background:none;border:0;color:var(--accent);font-family:var(--body);font-size:13px;cursor:pointer;padding:0}
.cb-link:hover{text-decoration:underline}
.cb-row{display:flex;gap:10px;align-items:center}
.cb-mt{margin-top:18px}
.cb-textcenter{text-align:center}

/* message line */
.cb-msg{font-family:var(--mono);font-size:11.5px;letter-spacing:.02em;margin-top:14px;min-height:16px}
.cb-msg.err{color:var(--err)}
.cb-msg.ok{color:var(--ok)}
.cb-msg.info{color:var(--muted)}

/* account menu */
.cb-acct{position:relative}
.cb-acct-btn{display:flex;align-items:center;gap:9px;background:var(--panel-2);border:1px solid var(--line-2);border-radius:100px;
  padding:7px 8px 7px 14px;cursor:pointer;color:var(--text);font-family:var(--body);font-size:13px}
.cb-acct-btn:hover{border-color:var(--accent)}
.cb-avatar{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#0a0e13;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:13px}
.cb-acct-menu{position:absolute;right:0;top:46px;background:var(--panel-2);border:1px solid var(--line-2);border-radius:14px;padding:8px;min-width:220px;z-index:20;box-shadow:0 24px 60px -18px rgba(0,0,0,.7)}
.cb-acct-menu .who{padding:10px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}
.cb-acct-menu .who .e{font-size:13px}
.cb-acct-menu .who .r{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-top:3px}
.cb-acct-menu button{display:flex;width:100%;align-items:center;gap:10px;background:none;border:0;color:var(--text);
  font-family:var(--body);font-size:13px;text-align:left;padding:10px 12px;border-radius:9px;cursor:pointer}
.cb-acct-menu button:hover{background:var(--panel-3)}

/* device grid */
.cb-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:8px 0 20px}
.cb-h2{font-family:var(--disp);font-weight:800;font-size:clamp(26px,3vw,34px);letter-spacing:-.02em;margin:6px 0 0}
.cb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.cb-dev{position:relative;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line-2);border-radius:18px;
  padding:22px;cursor:pointer;transition:.18s;overflow:hidden}
.cb-dev:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 22px 50px -22px rgba(255,158,27,.5)}
.cb-dev.dis{cursor:not-allowed;opacity:.7}
.cb-dev.dis:hover{transform:none;border-color:var(--line-2);box-shadow:none}
.cb-dev .glow{position:absolute;inset:-40% 40% auto -40%;height:200px;background:radial-gradient(circle,rgba(255,158,27,.14),transparent 70%);pointer-events:none}
.cb-dev .pic{height:188px;display:grid;place-items:center;margin-bottom:14px;position:relative}
.cb-dev .pic svg{filter:drop-shadow(0 10px 24px rgba(0,0,0,.5))}
.cb-dev .pic .skin-img{max-height:188px;max-width:78%;object-fit:contain;
  filter:drop-shadow(0 18px 34px rgba(0,0,0,.6)) drop-shadow(0 0 28px rgba(255,158,27,.18));
  transition:transform .35s cubic-bezier(.22,1,.36,1)}
.cb-dev:hover .pic .skin-img{transform:translateY(-4px) scale(1.03)}
.cb-dev .skin-tag{position:absolute;left:18px;bottom:14px;font-family:var(--mono);font-size:9.5px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:6px}
.cb-dev .skin-tag .sw{width:8px;height:8px;border-radius:50%;border:1px solid rgba(255,255,255,.25)}
.cb-dev .name{font-family:var(--disp);font-weight:800;font-size:21px;letter-spacing:-.01em}
.cb-dev .tag{color:var(--muted);font-size:12.5px;margin-top:2px}
.cb-dev .meta{display:flex;align-items:center;gap:8px;margin-top:14px}
.cb-pill{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--line-2);border-radius:100px;padding:5px 11px;color:var(--muted)}
.cb-pill .d{width:6px;height:6px;border-radius:50%;background:var(--ok)}
.cb-pill.warn{color:var(--accent);border-color:rgba(255,158,27,.4)}
.cb-pill.warn .d{background:var(--accent)}
.cb-dev .go{position:absolute;right:20px;bottom:20px;color:var(--accent);opacity:0;transform:translateX(-6px);transition:.18s}
.cb-dev:hover .go{opacity:1;transform:none}

/* empty / states */
.cb-empty{border:1px dashed var(--line-2);border-radius:18px;padding:48px 28px;text-align:center;color:var(--muted)}
.cb-empty .ico{color:var(--muted-2);margin-bottom:14px}
.cb-empty h3{font-family:var(--disp);color:var(--text);font-weight:700;font-size:19px;margin:0 0 6px}

/* modal */
.cb-overlay{position:fixed;inset:0;background:rgba(5,8,11,.72);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:50;padding:22px}
.cb-modal{width:min(520px,94vw);max-height:90vh;overflow:auto}
.cb-modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:6px}
.cb-x{background:none;border:0;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;padding:2px 6px}
.cb-x:hover{color:var(--text)}
textarea.cb-input{resize:vertical;min-height:110px;font-size:14px;line-height:1.5}
.cb-loglines{font-family:var(--mono);font-size:10.5px;color:var(--muted-2);background:var(--bg);border:1px solid var(--line);
  border-radius:10px;padding:11px;max-height:130px;overflow:auto;white-space:pre-wrap;word-break:break-all;margin-top:10px}

/* toast */
.cb-toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(14px);opacity:0;
  background:var(--panel-3);border:1px solid var(--line-2);border-radius:100px;padding:12px 20px;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;z-index:60;transition:.25s;pointer-events:none}
.cb-toast.show{opacity:1;transform:translateX(-50%)}
.cb-toast.ok{border-color:rgba(43,182,115,.5)}
.cb-toast.err{border-color:rgba(229,72,77,.5)}

.cb-foot{margin-top:48px;color:var(--muted-2);font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;text-align:center}
.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(10,14,19,.35);border-top-color:#0a0e13;border-radius:50%;animation:cbspin .6s linear infinite}
.cb-btn.ghost .spin{border:2px solid var(--line-2);border-top-color:var(--accent)}
@keyframes cbspin{to{transform:rotate(360deg)}}

/* sign-in hint banner — shown to logged-out visitors on the device page */
.cb-signin-hint{display:flex;align-items:center;gap:14px;justify-content:space-between;
  background:rgba(255,158,27,.07);border:1px solid rgba(255,158,27,.22);border-radius:14px;
  padding:12px 16px;margin:0 0 18px;font-size:13.5px;color:rgba(255,255,255,.72);line-height:1.5}
.cb-signin-hint b{color:#fff;font-weight:700}
.cb-signin-hint .cb-link{flex:none;white-space:nowrap}
