/* ===========================================================
   IjoSema  ·  ijosema.kymafoundry.com
   Clean, commercial product-signal identity. No mascot.
   Indigo + signal-cyan on cool white. Vanilla CSS.
   (Shares class names with Signal Desk so both pages use this file.)
   =========================================================== */

:root{
  --ink:#0f172a; --ink-soft:#52617a;
  --bg:#ffffff; --bg-2:#f5f7fb; --card:#ffffff;
  --accent:#4f46e5; --accent-d:#4338ca;   /* indigo */
  --cyan:#0ea5e9;                          /* signal cyan */
  --line:#e3e8f0;
  --shadow:0 20px 45px -22px rgba(30,41,90,.40);
  --r:16px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:17px; line-height:1.6;
  background:
    radial-gradient(1100px 600px at 88% -12%, #eef0ff 0%, transparent 60%),
    radial-gradient(800px 500px at -5% 110%, #e6f6ff 0%, transparent 55%),
    var(--bg);
  background-attachment:fixed;
}
.wrap{max-width:1080px; margin:0 auto; padding:0 24px; position:relative; z-index:1;}
h1,h2,h3{font-family:"Sora",system-ui,sans-serif; line-height:1.1; margin:0; letter-spacing:-.02em;}
a{color:var(--accent-d); text-underline-offset:3px;}
.eyebrow{font-weight:800; letter-spacing:.16em; text-transform:uppercase; font-size:12px; color:var(--accent);}

/* ---------- nav (dark, to seat the logo) ---------- */
nav{position:sticky; top:0; z-index:50; backdrop-filter:saturate(1.2) blur(8px);
  background:rgba(8,8,18,.88); border-bottom:1px solid #1c1c2e;}
nav .wrap{display:flex; align-items:center; gap:14px; padding:11px 24px;}
.brand{display:flex; align-items:center; gap:11px; text-decoration:none; color:#fff;}
.brand img.orb{width:42px; height:42px; object-fit:contain;}
.brand .name{font-family:"Sora",sans-serif; font-weight:800; font-size:21px; letter-spacing:-.01em; line-height:1; color:#fff;}
.brand .name b{background:linear-gradient(120deg,#7c6cf5,#a855f7); -webkit-background-clip:text; background-clip:text; color:transparent; font-weight:800;}
.brand .sub{font-size:11px; color:#9aa3b8; margin-top:2px;}
nav .spacer{flex:1;}
.nav-cta{background:var(--accent); color:#fff; text-decoration:none; font-weight:700; font-size:14px;
  padding:9px 16px; border-radius:10px; transition:filter .15s, transform .1s;}
.nav-cta:hover{filter:brightness(1.12);} .nav-cta:active{transform:scale(.98);}

/* ---------- hero (dark band, seats the full lockup) ---------- */
.hero{padding:0;}
.hero .darkband{background:radial-gradient(900px 500px at 70% 30%, #1a1640 0%, #060611 70%); padding:46px 0 54px;}
.hero .wrap{display:grid; grid-template-columns:1fr; gap:14px; align-items:center; text-align:center;}
.hero .lockup{width:100%; max-width:680px; margin:0 auto; display:block;}
.hero .eyebrow{color:#9f8bff;}
.hero p.lede{font-size:18px; color:#c4cbe0; margin:14px auto 26px; max-width:50ch;}
.cta-row{display:flex; gap:13px; flex-wrap:wrap; align-items:center; justify-content:center;}
.btn{display:inline-block; text-decoration:none; font-weight:700; border-radius:12px; padding:13px 22px;
  transition:filter .15s, transform .1s; cursor:pointer; border:none; font:inherit; font-weight:700;}
.btn-primary{background:var(--accent); color:#fff; box-shadow:0 12px 24px -12px rgba(79,70,229,.85);}
.btn-primary:hover{filter:brightness(1.08);} .btn-primary:active{transform:translateY(1px);}
.btn-ghost{background:#fff; color:var(--ink); border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent-d);}

/* signal-wave hero visual */
.hero-art{display:flex; align-items:center; justify-content:center;}
.wavecard{width:100%; max-width:380px; aspect-ratio:1/1; border-radius:24px;
  background:linear-gradient(145deg,#1e1b4b,#3730a3 60%,#0ea5e9); position:relative; overflow:hidden;
  box-shadow:var(--shadow); display:flex; align-items:center; justify-content:center;}
.wavecard .rings{position:absolute; inset:0; display:flex; align-items:center; justify-content:center;}
.wavecard .rings span{position:absolute; border:2px solid rgba(255,255,255,.35); border-radius:50%;
  animation:pulse 3s ease-out infinite;}
.wavecard .rings span:nth-child(1){width:80px;height:80px;animation-delay:0s;}
.wavecard .rings span:nth-child(2){width:160px;height:160px;animation-delay:.6s;}
.wavecard .rings span:nth-child(3){width:250px;height:250px;animation-delay:1.2s;}
.wavecard .dot{width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 0 24px 6px rgba(255,255,255,.7);}
@keyframes pulse{0%{opacity:.7;transform:scale(.6);}100%{opacity:0;transform:scale(1.1);}}
@media (prefers-reduced-motion:reduce){.wavecard .rings span{animation:none;opacity:.4;}}

/* ---------- sections ---------- */
section.block{padding:54px 0;}
.block h2{font-size:clamp(27px,4vw,38px); font-weight:800; margin:8px 0 6px;}
.block .sub{color:var(--ink-soft); max-width:56ch; margin-bottom:30px;}

.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.step{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px 22px; box-shadow:var(--shadow); position:relative;}
.step .n{position:absolute; top:-15px; left:22px; width:32px; height:32px; border-radius:9px;
  background:linear-gradient(135deg,var(--accent),var(--cyan)); color:#fff; font-family:"Sora",sans-serif; font-weight:800;
  display:flex; align-items:center; justify-content:center; font-size:15px;}
.step h3{font-size:19px; margin:10px 0 8px; font-weight:700;}
.step p{margin:0; color:var(--ink-soft); font-size:15px;}

/* friction chips */
.flags{display:flex; flex-wrap:wrap; gap:10px; margin-top:6px;}
.flag{background:var(--bg-2); border:1px solid var(--line); color:var(--ink); font-weight:600; font-size:14px; padding:8px 14px; border-radius:10px;}

/* positioning band */
.band{background:linear-gradient(135deg,#1e1b4b,#4338ca 60%,#0ea5e9); color:#fff; border-radius:22px; padding:44px 36px; box-shadow:var(--shadow);}
.band h2{color:#fff; max-width:20ch;}
.band p{color:rgba(255,255,255,.9); max-width:60ch; margin:12px 0 0;}
.chips{display:flex; flex-wrap:wrap; gap:11px; margin-top:18px;}
.chip{background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3); color:#fff; font-weight:600; font-size:14px; padding:8px 14px; border-radius:999px;}

.dogfood{background:var(--card); border:1px solid var(--line); border-left:4px solid var(--accent); border-radius:var(--r); padding:28px; box-shadow:var(--shadow);}
.dogfood h2{color:var(--accent-d); margin-bottom:6px;}
.dogfood p{color:var(--ink-soft); margin:0; max-width:54ch;}

footer{border-top:1px solid var(--line); margin-top:30px; padding:32px 0 48px;}
footer .wrap{display:flex; align-items:center; gap:13px; flex-wrap:wrap;}
footer .name{font-family:"Sora",sans-serif; font-weight:800;}
footer small{color:var(--ink-soft);} footer .spacer{flex:1;}

@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0; transform:translateY(14px); animation:rise .7s ease forwards;}
  .d1{animation-delay:.05s;} .d2{animation-delay:.15s;} .d3{animation-delay:.28s;} .d4{animation-delay:.4s;}
  @keyframes rise{to{opacity:1; transform:none;}}
}
@media (max-width:820px){
  .hero .wrap{grid-template-columns:1fr; text-align:center;}
  .hero p.lede{margin-left:auto;margin-right:auto;}
  .cta-row{justify-content:center;} .hero-art{order:-1;}
  .steps{grid-template-columns:1fr;}
}

/* ===========================================================
   SIGNAL DESK (admin) — shares tokens above
   =========================================================== */
.admin-main{max-width:1180px; margin:0 auto; padding:24px;}
.gate{max-width:430px; margin:60px auto; background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:30px 28px; box-shadow:var(--shadow); text-align:center;}
.gate h2{font-size:23px; margin-bottom:6px;}
.gate p{color:var(--ink-soft); font-size:14px; margin:0 0 18px;}
.gate input{width:100%; padding:12px 14px; border:1.5px solid var(--line); border-radius:10px; font:inherit; margin-bottom:12px;}
.gate input:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(79,70,229,.15);}
.gate .err{color:#dc2626; font-size:13px; min-height:16px; margin-top:6px;}

.admin-bar{display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:6px 0 18px;}
.admin-bar h2{font-size:25px; font-weight:800;}
.admin-bar .spacer{flex:1;}
.admin-bar select, .admin-bar button.mini{font:inherit; font-size:14px; padding:8px 12px; border-radius:9px; border:1.5px solid var(--line); background:var(--card); color:var(--ink); cursor:pointer;}
.admin-bar button.mini{background:var(--accent); color:#fff; border:none; font-weight:700;}
.logout{background:transparent !important; color:var(--ink-soft) !important; border:1.5px solid var(--line) !important;}

.addbug{background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:18px 20px; box-shadow:var(--shadow); margin-bottom:22px;}
.addbug h3{font-size:18px; margin-bottom:12px;}
.addbug .row{display:grid; grid-template-columns:200px 1fr; gap:12px; margin-bottom:10px;}
.addbug input, .addbug select, .addbug textarea{width:100%; padding:10px 12px; border:1.5px solid var(--line); border-radius:9px; font:inherit; background:#fff;}
.addbug textarea{min-height:64px; resize:vertical;}
.addbug .submit{background:var(--accent); color:#fff; border:none; border-radius:10px; padding:11px 20px; font-weight:700; cursor:pointer;}
.addbug .note{font-size:12px; color:var(--ink-soft); margin-top:6px;}

table.bugs{width:100%; border-collapse:collapse; background:var(--card); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow);}
table.bugs th{background:linear-gradient(135deg,var(--accent),var(--accent-d)); color:#fff; text-align:left; font-size:12px; letter-spacing:.05em; text-transform:uppercase; padding:11px 12px;}
table.bugs td{padding:11px 12px; border-top:1px solid var(--line); font-size:14px; vertical-align:top;}
table.bugs tr:hover td{background:#f8faff;}
.msg-cell{max-width:360px;}
.url-cell{max-width:190px; font-size:12px; color:var(--accent-d); word-break:break-all;}
.pill{display:inline-block; font-size:11px; font-weight:800; padding:3px 9px; border-radius:999px; text-transform:uppercase; letter-spacing:.04em;}
.pill.new{background:#e0e7ff; color:#3730a3;}
.pill.triaged{background:#cffafe; color:#0e7490;}
.pill.in_progress{background:#fef9c3; color:#854d0e;}
.pill.resolved{background:#dcfce7; color:#166534;}
.pill.closed{background:#e2e8f0; color:#334155;}
.pill.wontfix{background:#fee2e2; color:#991b1b;}
.act{display:flex; gap:6px; flex-wrap:wrap;}
.act button{font:inherit; font-size:12px; font-weight:700; padding:5px 9px; border-radius:7px; border:1.5px solid var(--line); background:#fff; cursor:pointer;}
.act button.fix{background:var(--accent); color:#fff; border:none;}
.act button.fix:hover{filter:brightness(1.08);}
.empty{text-align:center; color:var(--ink-soft); padding:40px;}
.prodtag{font-weight:800; color:var(--ink);}
