/* tauhan-core.css — shared styles for all Tauhan.AI client portals */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=DM+Sans:wght@400;500;600&display=swap');

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

/* Light theme — brand color injected via --terra from client config */
.L{
  --indigo:#6C63FF;--indigo2:#5A52E8;--cyan:#00D4FF;
  --gold:#FFB800;--ok:#2D8653;--cor:#FF4D4D;
  --bg:#F8F9FF;--sb:#F2F3FF;--card:#FFFFFF;
  --b:#E0DFFF;--b2:#C8C6FF;
  --tx:#1A1A2E;--tx2:#5A5A8A;--tx3:#9090B8;
  --inp:#FFFFFF;--hov:#EEEEFF;--chip:#FFFFFF;
  --ai-bg:rgba(108,99,255,0.08);--ai-border:rgba(108,99,255,0.2);
}
.D{
  --indigo:#8B85FF;--indigo2:#6C63FF;--cyan:#00D4FF;
  --gold:#FFB800;--ok:#52B788;--cor:#FF6B6B;
  --bg:#0D0E1C;--sb:#12132A;--card:#1A1B35;
  --b:#2A2B50;--b2:#3A3B65;
  --tx:#E8E9FF;--tx2:#9090C8;--tx3:#5A5A8A;
  --inp:#1A1B35;--hov:#1A1B35;--chip:#1A1B35;
  --ai-bg:rgba(139,133,255,0.12);--ai-border:rgba(139,133,255,0.25);
}

body{font-family:'DM Sans',sans-serif;font-size:14px}
.shell{display:flex;height:100vh;background:var(--bg);overflow:hidden}

/* Sidebar */
.sb{width:210px;flex-shrink:0;display:flex;flex-direction:column;background:var(--sb);border-right:0.5px solid var(--b)}
.sb-logo{padding:16px;border-bottom:0.5px solid var(--b)}
.lr{display:flex;align-items:center;gap:8px}
.li{width:30px;height:30px;border-radius:9px;background:var(--terra);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;font-family:'Sora',sans-serif}
.lt{font-size:14px;font-weight:800;color:var(--terra);font-family:'Sora',sans-serif}
.lt span{color:var(--indigo)}
.ls{font-size:10px;color:var(--tx3);margin-top:2px;padding-left:38px}
.ai-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;background:var(--ai-bg);border:1px solid var(--ai-border);border-radius:6px;padding:2px 7px;color:var(--indigo);margin-top:6px;width:100%;justify-content:center}
.ns{padding:10px 14px 3px;font-size:9px;font-weight:700;letter-spacing:.08em;color:var(--tx3);text-transform:uppercase}
.ni{display:flex;align-items:center;gap:9px;padding:8px 12px;border-radius:9px;cursor:pointer;font-size:12px;margin:1px 7px;color:var(--tx2);transition:all .13s}
.ni:hover{background:var(--hov);color:var(--terra)}
.ni.on{background:var(--terra);color:#fff}
.nd{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.nd-ai{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:var(--indigo)}
.sb-bot{margin-top:auto;padding:12px 14px;border-top:0.5px solid var(--b)}
.urow{display:flex;align-items:center;gap:9px}
.uface{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--b2)}
.uface img{width:100%;height:100%;object-fit:cover}
.un{font-size:12px;font-weight:600;color:var(--tx)}
.up{font-size:10px;color:var(--tx3);margin-top:1px}
.sb-acts{display:flex;gap:6px;margin-top:10px}
.sb-act{flex:1;padding:5px;border-radius:7px;font-size:10px;font-weight:600;text-align:center;cursor:pointer;border:0.5px solid var(--b2);color:var(--tx2);background:var(--card)}
.sb-act:hover{border-color:var(--terra);color:var(--terra)}

/* Main area */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:0.5px solid var(--b);background:var(--card);flex-shrink:0}
.tb-l{display:flex;align-items:center;gap:10px}
.tb-t{font-size:14px;font-weight:700;color:var(--tx)}
.tb-b{font-size:10px;padding:3px 8px;border-radius:20px;background:var(--hov);color:var(--terra);font-weight:600}
.tb-r{display:flex;align-items:center;gap:8px}
.ai-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:3px 9px;border-radius:20px;background:var(--ai-bg);color:var(--indigo);font-weight:600;border:1px solid var(--ai-border)}
.plan-pill{font-size:11px;padding:4px 10px;border-radius:20px;background:var(--terra);color:#fff;font-weight:600;cursor:pointer}
.content{flex:1;overflow-y:auto;padding:16px 18px}

/* Stats grid */
.sgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:18px}
.sc{background:var(--card);border:0.5px solid var(--b);border-radius:11px;padding:13px}
.scl{font-size:10px;color:var(--tx3);margin-bottom:4px;font-weight:500}
.scv{font-size:21px;font-weight:700;color:var(--tx)}
.scs{font-size:10px;margin-top:3px;color:var(--ok)}

/* Agent cards */
.sec{font-size:11px;font-weight:700;color:var(--tx);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.see{font-size:10px;color:var(--terra);cursor:pointer;font-weight:600}
.agrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}
.ac{background:var(--card);border:0.5px solid var(--b);border-radius:11px;padding:12px;cursor:pointer;transition:border-color .13s}
.ac:hover{border-color:var(--terra)}
.ac.orch{border:1.5px solid var(--indigo)}
.ac.orch:hover{border-color:var(--indigo2)}
.ac-top{display:flex;align-items:center;gap:9px;margin-bottom:8px}
.ac-face{width:34px;height:34px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--b)}
.ac-face img{width:100%;height:100%;object-fit:cover}
.acn{font-size:12px;font-weight:700;color:var(--tx)}
.acr{font-size:10px;color:var(--tx3)}
.acst{display:flex;align-items:center;gap:5px;font-size:10px;margin-bottom:7px}
.dot{width:6px;height:6px;border-radius:50%}
.acex{font-size:10px;background:var(--bg);border-radius:7px;padding:6px 8px;color:var(--tx3);line-height:1.45;font-style:italic}
.dtabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:13px}
.dtab{padding:5px 11px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:0.5px solid var(--b2);background:var(--card);color:var(--tx2);transition:all .13s}

/* Orchestrator card */
.orch-card{background:var(--ai-bg);border:1.5px solid var(--indigo);border-radius:12px;padding:14px;display:flex;align-items:center;gap:14px;cursor:pointer;margin-bottom:18px;transition:background .13s}
.orch-card:hover{background:rgba(108,99,255,.14)}
.orch-face{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--indigo)}
.ob-ai{font-size:10px;background:var(--indigo);color:#fff;padding:2px 8px;border-radius:20px;font-weight:700}
.ob{font-size:10px;background:var(--gold);color:#2C1810;padding:2px 8px;border-radius:20px;font-weight:700}
.oo{font-size:11px;background:var(--indigo);color:#fff;padding:5px 12px;border-radius:20px;font-weight:600;flex-shrink:0}

/* Chat */
.chat-wrap{display:flex;flex-direction:column;height:100%}
.c-hdr{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:0.5px solid var(--b);margin-bottom:12px;flex-shrink:0}
.c-back{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:0.5px solid var(--b2);color:var(--tx2);font-size:14px}
.c-back:hover{border-color:var(--terra);color:var(--terra)}
.c-face{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--b)}
.c-msgs{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:2px}
.m-u{align-self:flex-end;max-width:75%}
.m-a{align-self:flex-start;max-width:80%}
.b-u{background:var(--terra);color:#fff;border-radius:12px 12px 3px 12px;padding:9px 12px;font-size:12px;line-height:1.55}
.b-a{background:var(--card);border:0.5px solid var(--b);color:var(--tx);border-radius:12px 12px 12px 3px;padding:9px 12px;font-size:12px;line-height:1.6}
.mt{font-size:9px;color:var(--tx3);margin-top:4px;text-align:right}
.m-a .mt{text-align:left}
.appr{display:flex;gap:6px;margin-top:8px}
.ab{padding:4px 10px;border-radius:7px;font-size:10px;font-weight:700;border:none;cursor:pointer;font-family:'DM Sans',sans-serif}
.aok{background:var(--terra);color:#fff}
.aed{background:transparent;color:var(--terra);border:0.5px solid var(--terra)!important}
.arj{background:transparent;color:var(--cor);border:0.5px solid var(--cor)!important}
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.chip{font-size:10px;padding:5px 9px;border-radius:7px;cursor:pointer;border:0.5px solid var(--b2);background:var(--chip);color:var(--tx2)}
.chip:hover{border-color:var(--terra);color:var(--terra)}
.c-inp-row{display:flex;gap:8px;padding-top:12px;border-top:0.5px solid var(--b);margin-top:10px;flex-shrink:0;align-items:center}
.c-inp{flex:1;border-radius:9px;border:0.5px solid var(--b2);padding:9px 12px;font-size:12px;outline:none;background:var(--inp);color:var(--tx)}
.c-inp:focus{border-color:var(--terra)}
.c-send{width:36px;height:36px;border-radius:9px;background:var(--terra);border:none;color:#fff;cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.c-send:disabled{opacity:.5;cursor:not-allowed}

/* DNA */
.dna-field{margin-bottom:13px}
.dna-label{font-size:10px;font-weight:700;color:var(--tx3);margin-bottom:4px;letter-spacing:.05em;text-transform:uppercase}
.dna-inp{width:100%;border-radius:9px;border:0.5px solid var(--b2);padding:9px 11px;font-size:12px;color:var(--tx);background:var(--inp);outline:none}
.dna-inp:focus{border-color:var(--terra)}
.dna-ta{width:100%;border-radius:9px;border:0.5px solid var(--b2);padding:9px 11px;font-size:12px;color:var(--tx);background:var(--inp);outline:none;resize:vertical;min-height:70px;font-family:'DM Sans',sans-serif}
.dna-ta:focus{border-color:var(--terra)}
.save-btn{background:var(--terra);color:#fff;border:none;border-radius:9px;padding:10px 22px;font-size:12px;font-weight:700;cursor:pointer}
.cardbox{background:var(--card);border:0.5px solid var(--b);border-radius:11px;padding:14px;margin-bottom:14px}

/* Typing indicator */
.typing{display:flex;gap:4px;align-items:center;padding:8px 12px;background:var(--card);border:0.5px solid var(--b);border-radius:12px;width:fit-content}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--tx3);animation:ty .9s infinite}
.typing span:nth-child(2){animation-delay:.15s}
.typing span:nth-child(3){animation-delay:.3s}
@keyframes ty{0%,80%,100%{transform:scale(.7);opacity:.5}40%{transform:scale(1);opacity:1}}

/* Memory tab */
.mem-agent-card{background:var(--card);border:0.5px solid var(--b);border-radius:11px;padding:14px;margin-bottom:10px}
.mem-agent-name{font-size:12px;font-weight:700;color:var(--tx);display:flex;align-items:center;gap:8px;margin-bottom:8px}
.mem-count{font-size:10px;background:var(--ai-bg);border:1px solid var(--ai-border);color:var(--indigo);padding:1px 7px;border-radius:10px;font-weight:600}
.mem-topic{font-size:11px;color:var(--tx2);padding:4px 0;border-bottom:0.5px solid var(--b);display:flex;align-items:center;gap:6px}
.mem-topic:last-child{border:none}
.mem-last{font-size:10px;color:var(--tx3);margin-top:6px}
.mem-continue{font-size:10px;font-weight:600;color:var(--terra);cursor:pointer;padding:4px 9px;border:0.5px solid var(--terra);border-radius:6px;background:transparent;margin-top:8px}
.mem-continue:hover{background:var(--terra);color:#fff}
.mem-empty{text-align:center;padding:40px 20px;color:var(--tx3);font-size:12px}

/* Mobile */
@media(max-width:640px){
  .sb{width:180px}
  .agrid{grid-template-columns:repeat(2,1fr)}
  .sgrid{grid-template-columns:repeat(3,1fr)}
}
