/* ==========================================================================
   aiRA product app — LIGHT theme (Ask aiRA + AI Workspace)
   Matches the in-product screenshots: white surfaces, navy ink, green primary,
   indigo accent, soft gray lines.
   ========================================================================== */
:root{
  --bg:#F6F8FA; --surface:#FFFFFF; --surface-2:#F1F3F5; --surface-3:#FBFCFD;
  --line:#E7E9ED; --line-2:#DCE0E6;
  --ink:#162844; --ink-2:#48526A; --ink-3:#8A93A3;
  --green:#2FA45A; --green-d:#23894A; --green-soft:#E7F4EC;
  --indigo:#5660F0; --indigo-d:#4049D6; --indigo-soft:#EEEFFE;
  --amber:#E08A2B; --amber-soft:#FBEFD9; --amber-ink:#9A5E12;
  --navy:#16243D;
  --r-sm:8px; --r-md:10px; --r-lg:14px; --r-xl:18px; --pill:999px;
  --sans:'Roboto', system-ui, -apple-system, sans-serif;
  --mono:'Roboto Mono', ui-monospace, monospace;
  --shadow:0 1px 2px rgba(20,30,50,.04), 0 8px 24px -16px rgba(20,30,50,.18);
  --shadow-lg:0 24px 60px -24px rgba(20,30,50,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; background:var(--bg); color:var(--ink-2); font-family:var(--sans);
  font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased}
a{color:inherit; text-decoration:none}
svg{display:block}
:focus-visible{outline:2px solid var(--indigo); outline-offset:2px; border-radius:4px}
h1,h2,h3,h4{margin:0; color:var(--ink); font-weight:600; letter-spacing:-.01em}

/* buttons */
.gbtn{display:inline-flex; align-items:center; gap:8px; background:var(--green); color:#fff;
  border:none; border-radius:var(--r-md); padding:10px 16px; font-family:var(--sans); font-size:14px;
  font-weight:500; cursor:pointer; transition:background .15s}
.gbtn:hover{background:var(--green-d)}
.obtn{display:inline-flex; align-items:center; gap:7px; background:var(--surface); color:var(--ink);
  border:1px solid var(--line-2); border-radius:var(--r-md); padding:8px 14px; font-size:13px; font-weight:500; cursor:pointer; transition:all .15s}
.obtn:hover{border-color:var(--ink-3); background:var(--surface-2)}
.iconbtn{width:38px;height:38px;border-radius:var(--r-md); display:grid;place-items:center; color:var(--ink-2);
  background:transparent; border:none; cursor:pointer; transition:background .15s}
.iconbtn:hover{background:var(--surface-2)}
.avatar{width:36px;height:36px;border-radius:50%; background:var(--indigo); color:#fff; display:grid;place-items:center;
  font-size:13px; font-weight:600}

/* ===================== APP SHELL (workspace) ===================== */
.app{display:grid; grid-template-rows:auto 1fr; min-height:100vh}
.app-top{display:flex; align-items:center; gap:16px; height:64px; padding:0 22px;
  background:var(--surface); border-bottom:1px solid var(--line)}
.brand{display:flex; align-items:center; gap:10px}
.brand .clogo{width:30px;height:30px;border-radius:8px; background:var(--green); color:#fff; display:grid;place-items:center; font-weight:700}
.brand .cw{font-weight:600; color:var(--ink); font-size:17px}
.aira-badge{background:var(--navy); color:#fff; font-size:12px; font-weight:600; letter-spacing:.04em;
  padding:5px 12px; border-radius:var(--pill)}
.ctx{display:flex; align-items:center; gap:10px; color:var(--ink-3); font-size:13px}
.ctx .ws{display:inline-flex; align-items:center; gap:6px; background:var(--surface-2); border-radius:var(--pill); padding:6px 12px; color:var(--ink-2)}
.app-top .grow{flex:1}
.search{display:flex; align-items:center; gap:9px; background:var(--surface-2); border:1px solid transparent;
  border-radius:var(--r-md); padding:9px 14px; width:340px; max-width:38vw; color:var(--ink-3); font-size:14px}
.search:focus-within{border-color:var(--line-2); background:var(--surface)}
.search input{border:none; background:transparent; outline:none; flex:1; font-family:var(--sans); font-size:14px; color:var(--ink)}

.app-body{display:grid; grid-template-columns:248px 1fr}
.app-side{background:var(--surface); border-right:1px solid var(--line); padding:20px 14px; position:relative}
.side-sec{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); font-weight:500; margin:6px 10px 8px}
.nav-item{display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:var(--r-md); cursor:pointer;
  color:var(--ink-2); font-size:14px; font-weight:500; margin-bottom:2px; transition:background .15s}
.nav-item:hover{background:var(--surface-2)}
.nav-item.active{background:var(--indigo-soft); color:var(--indigo-d)}
.nav-item.active svg{color:var(--indigo)}
.nav-item .ni-ic{color:var(--ink-3); display:grid;place-items:center}
.nav-item.active .ni-ic{color:var(--indigo)}
.nav-item .ct{margin-left:auto; font-size:12px; color:var(--ink-3); font-variant-numeric:tabular-nums}
.nav-item.active .ct{color:var(--indigo-d)}
.side-div{height:1px; background:var(--line); margin:16px 8px}
.tip{position:absolute; left:14px; right:14px; bottom:16px; background:var(--indigo-soft);
  border:1px solid #DDD9FB; border-radius:var(--r-lg); padding:14px}
.tip .th{display:flex; align-items:center; gap:7px; color:var(--indigo-d); font-weight:500; font-size:13px; margin-bottom:6px}
.tip p{margin:0; font-size:12.5px; color:#5b5fa6; line-height:1.5}

.app-main{padding:34px 40px; overflow:auto}
.pg-h{display:flex; align-items:flex-start; justify-content:space-between; gap:20px; margin-bottom:26px}
.pg-h h1{font-size:30px}
.pg-h p{margin:8px 0 0; color:var(--ink-3); font-size:15px}

/* filter pills */
.pills{display:flex; gap:10px; margin-bottom:22px}
.pill{padding:7px 16px; border-radius:var(--pill); border:1px solid var(--line-2); background:var(--surface);
  font-size:13px; color:var(--ink-2); cursor:pointer; transition:all .15s}
.pill:hover{border-color:var(--ink-3)}
.pill.active{border-color:var(--indigo); color:var(--indigo-d); background:var(--indigo-soft)}

/* card grids */
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:22px; transition:all .15s; cursor:pointer}
.card:hover{border-color:var(--line-2); box-shadow:var(--shadow); transform:translateY(-2px)}
.card-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:16px}
.ic-box{width:38px;height:38px;border-radius:10px; background:var(--surface-2); display:grid;place-items:center; color:var(--ink)}
.cat{font-size:12px; color:var(--ink-2); background:var(--surface-2); border-radius:var(--pill); padding:4px 11px}
.card h3{font-size:17px; margin-bottom:7px}
.card .desc{font-size:14px; color:var(--ink-3); line-height:1.5; margin:0}
.card .foot{margin-top:18px; padding-top:14px; border-top:1px solid var(--line); font-size:13px; color:var(--ink-3)}

/* status */
.st{display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:500}
.st i{width:7px;height:7px;border-radius:50%}
.st.live{color:var(--green-d)} .st.live i{background:var(--green)}
.st.draft{color:var(--ink-3)} .st.draft i{background:var(--ink-3)}
.st.paused{color:var(--amber-ink)} .st.paused i{background:var(--amber)}

/* tags */
.tags{display:flex; flex-wrap:wrap; gap:8px; margin-top:14px}
.tag{display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:var(--ink-2);
  background:var(--surface-2); border-radius:var(--pill); padding:5px 11px}
.tag svg{color:var(--ink-3)}

/* agent / workflow card stat row */
.statrow{display:flex; align-items:center; gap:26px; margin-top:18px; padding-top:16px; border-top:1px solid var(--line)}
.statrow .big{font-size:20px; font-weight:600; color:var(--ink)}
.statrow .lbl{font-size:12px; color:var(--ink-3)}
.statrow .delta{color:var(--green-d); font-weight:500; font-size:14px}
.statrow .spacer{flex:1}

/* agent/workflow header with robot icon */
.ag-head{display:flex; align-items:flex-start; gap:14px}
.ag-ic{width:42px;height:42px;border-radius:11px; background:var(--surface-2); display:grid;place-items:center; color:var(--ink); flex:none}
.ag-head h3{font-size:18px; display:flex; align-items:center; gap:12px; flex-wrap:wrap}
.ag-head .desc{margin:5px 0 0}

/* ===================== DRAWER ===================== */
.scrim{position:fixed; inset:0; background:rgba(20,30,50,.34); opacity:0; pointer-events:none; transition:opacity .25s; z-index:50}
.scrim.open{opacity:1; pointer-events:auto}
.drawer{position:fixed; top:0; right:0; height:100vh; width:480px; max-width:94vw; background:var(--surface);
  border-left:1px solid var(--line); box-shadow:var(--shadow-lg); transform:translateX(100%); transition:transform .3s cubic-bezier(.2,.7,.2,1);
  z-index:51; display:flex; flex-direction:column}
.drawer.open{transform:none}
.dr-h{display:flex; align-items:flex-start; gap:14px; padding:22px 24px; border-bottom:1px solid var(--line)}
.dr-h .ic-box{width:42px;height:42px}
.dr-h h2{font-size:19px} .dr-h .desc{margin:4px 0 0; font-size:14px; color:var(--ink-3)}
.dr-h .x{margin-left:auto; cursor:pointer; color:var(--ink-3)}
.dr-body{padding:22px 24px; overflow:auto; flex:1}
.fld{margin-bottom:18px}
.fld label{display:block; font-size:12px; font-weight:500; color:var(--ink-2); margin-bottom:7px; letter-spacing:.02em}
.fld input,.fld textarea,.fld select{width:100%; background:var(--surface-3); border:1px solid var(--line-2); border-radius:var(--r-md);
  padding:10px 12px; font-family:var(--sans); font-size:14px; color:var(--ink)}
.fld textarea{min-height:78px; resize:vertical}
.fld input:focus,.fld textarea:focus,.fld select:focus{outline:none; border-color:var(--indigo)}
.steplist{display:flex; flex-direction:column; gap:8px}
.step-row{display:flex; align-items:center; gap:10px; background:var(--surface-3); border:1px solid var(--line); border-radius:var(--r-md); padding:10px 12px; font-size:13.5px}
.step-row .num{width:22px;height:22px;border-radius:6px; background:var(--indigo-soft); color:var(--indigo-d); display:grid;place-items:center; font-size:12px; font-weight:600; flex:none}
.step-row .gr{margin-left:auto; color:var(--ink-3); cursor:grab}
.dr-foot{display:flex; justify-content:flex-end; gap:10px; padding:16px 24px; border-top:1px solid var(--line)}
.kv{display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--line); font-size:14px}
.kv .k{color:var(--ink-3)} .kv .v{color:var(--ink); font-weight:500}
.section-title{font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); font-weight:500; margin:6px 0 12px}

/* mini workflow chain in drawer */
.chain{display:flex; flex-direction:column; gap:0}
.chain .cn{display:flex; align-items:center; gap:12px; background:var(--surface-3); border:1px solid var(--line); border-radius:var(--r-md); padding:12px 14px}
.chain .cn .cic{width:30px;height:30px;border-radius:8px; background:var(--surface-2); display:grid;place-items:center; color:var(--ink)}
.chain .cn b{font-size:14px; color:var(--ink); font-weight:500; display:block}
.chain .cn span{font-size:12px; color:var(--ink-3)}
.chain .cdn{width:1px; height:16px; background:var(--line-2); margin-left:28px}

/* ===================== ASK aiRA ===================== */
.ask-top{display:flex; align-items:center; gap:14px; height:64px; padding:0 22px; background:var(--surface); border-bottom:1px solid var(--line)}
.ask-top .dots9{display:grid; grid-template-columns:repeat(3,4px); gap:3px; padding:4px; cursor:pointer}
.ask-top .dots9 i{width:4px;height:4px;border-radius:1px; background:var(--ink-3)}
.ask-top .ttl{font-weight:600; color:var(--ink); font-size:17px}
.ask-top .vbar{width:1px;height:26px;background:var(--line); margin:0 4px}
.ask-top .grow{flex:1}
.ask-wrap{min-height:calc(100vh - 64px); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:40px 22px}
.ask-inner{width:100%; max-width:760px; text-align:center}
.ask-spark{display:flex; justify-content:center; margin-bottom:22px}
.ask-spark svg{width:56px;height:56px}
.ask-hi{font-size:24px; color:var(--ink); font-weight:500; margin-bottom:26px}
.ask-composer{display:flex; align-items:center; gap:12px; background:var(--surface); border:1.5px solid var(--indigo);
  border-radius:var(--r-lg); padding:12px 14px; box-shadow:0 8px 28px -18px rgba(86,96,240,.5)}
.ask-composer .plus{width:30px;height:30px;border-radius:50%; background:var(--indigo); color:#fff; display:grid;place-items:center; flex:none; cursor:pointer}
.ask-composer input{flex:1; border:none; outline:none; font-family:var(--sans); font-size:16px; color:var(--ink); background:transparent}
.ask-composer .ci{color:var(--ink-3); cursor:pointer}
.ask-composer .send{color:var(--indigo); cursor:pointer}
.ask-cards{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin-top:18px; text-align:left}
.ask-card{min-width:0; background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-lg); padding:16px 18px; cursor:pointer; transition:all .15s}
.ask-card:hover{border-color:var(--indigo); box-shadow:var(--shadow)}
.ask-card h4{font-size:15px; margin-bottom:5px}
.ask-card p{margin:0; font-size:13px; color:var(--ink-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}

.toast{position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px); opacity:0;
  background:var(--navy); color:#fff; font-size:13px; padding:11px 18px; border-radius:var(--pill); transition:all .3s; z-index:80}
.toast.show{opacity:1; transform:translateX(-50%)}

/* spawn-in (hand-off from the demo) */
.card.spawning{opacity:0; transform:translateY(12px) scale(.985)}
.card.spawned{opacity:1; transform:none; transition:opacity .5s, transform .5s cubic-bezier(.2,.7,.2,1.1)}
.spawn-banner{display:flex; align-items:center; gap:11px; background:var(--indigo-soft); border:1px solid #DDD9FB; color:var(--indigo-d);
  border-radius:var(--r-lg); padding:13px 18px; margin-bottom:18px; font-size:14px; font-weight:500; transition:opacity .5s}
.spawn-banner.done{background:var(--green-soft); border-color:#BFE6CC; color:var(--green-d)}
.spawn-spinner{width:15px;height:15px;border:2px solid currentColor; border-right-color:transparent; border-radius:50%; animation:spin .7s linear infinite; flex:none}
@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width:900px){
  .app-body{grid-template-columns:1fr} .app-side{display:none}
  .grid3,.grid2,.ask-cards{grid-template-columns:1fr}
  .search{display:none}
}
