/* ═══ BiCAD v5 — Design System (cores da logo) ═══ */
:root{
--bg:#15171C;--bg2:#1A1D22;--bg3:#1F2228;--bg4:#252830;--bgh:#2A2D35;
--bd:#2A2D34;--bd2:#353840;--bd3:#40444D;
--gd:#C8A764;--gdh:#E2C882;--gdd:#8E7442;--gdbg:rgba(200,167,100,.07);--gdbg2:rgba(200,167,100,.13);
--tx:#D0D0D6;--tx2:#9A9AA4;--tx3:#6B6B78;--tx4:#4A4A56;
--cy:#4DD4E6;--vi:#9B7BF4;--gn:#5BD4A4;--rd:#E86B6B;--or:#E8944A;--pk:#E87BAE;
--sb:314px;--f:'DM Mono',monospace;--se:'Cormorant Garamond',serif;--tm:44px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--tx);font-family:var(--f);font-size:12px;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--bd2);border-radius:2px}
#app{display:flex;height:100dvh;width:100vw}

/* SIDEBAR */
#sidebar{width:var(--sb);min-width:var(--sb);background:var(--bg2);border-right:1px solid var(--bd);display:flex;flex-direction:column;overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1),min-width .3s,width .3s;z-index:60}
#sidebar.collapsed{transform:translateX(calc(-1*var(--sb)));min-width:0;width:0}
#side-header{padding:12px 16px 10px;border-bottom:1px solid var(--bd);background:linear-gradient(180deg,rgba(26,29,34,.9),var(--bg2));display:flex;align-items:center;gap:12px}
#header-logo{height:34px;width:auto;opacity:.92}
#header-text{flex:1}
#logo-title{font-family:var(--se);font-size:22px;font-weight:500;color:var(--gd);letter-spacing:1.5px;line-height:1}
#logo-sub{font-size:7px;color:var(--tx3);letter-spacing:2.5px;text-transform:uppercase;margin-top:2px}
#project-row{padding:6px 16px;border-bottom:1px solid var(--bd);background:var(--bg)}
#project-name{width:100%;padding:6px 8px;background:transparent;border:1px solid var(--bd);border-radius:3px;color:var(--tx2);font-family:var(--f);font-size:10px;outline:none;transition:border-color .2s}
#project-name:focus{border-color:var(--gdd);color:var(--tx)}
#side-content{flex:1;overflow-y:auto;padding:10px 14px;-webkit-overflow-scrolling:touch}

/* Sections */
.sec{margin-bottom:14px;animation:fadeIn .25s ease both}
.sec:nth-child(2){animation-delay:.03s}.sec:nth-child(3){animation-delay:.06s}
@keyframes fadeIn{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}
.sec-t{font-size:8.5px;font-weight:500;color:var(--tx3);letter-spacing:2px;text-transform:uppercase;margin-bottom:7px;display:flex;align-items:center;gap:6px}
.sec-t::after{content:'';flex:1;height:1px;background:var(--bd);opacity:.6}

/* Buttons — 44px touch */
.br{display:flex;gap:4px;flex-wrap:wrap}
.b{min-height:var(--tm);padding:8px 12px;background:var(--bg3);border:1px solid var(--bd);border-radius:4px;color:var(--tx2);font-size:10px;font-family:var(--f);cursor:pointer;transition:all .12s;display:inline-flex;align-items:center;gap:5px;user-select:none;white-space:nowrap;touch-action:manipulation}
.b:hover,.b:active{background:var(--bgh);color:var(--tx);border-color:var(--bd2)}
.b.act{background:var(--gd);color:var(--bg);border-color:var(--gd);font-weight:500}
.b.gld{background:var(--gd);color:var(--bg);border:none;font-weight:500}
.b.gld:hover,.b.gld:active{background:var(--gdh)}
.b.dgr{color:var(--rd);border-color:rgba(232,107,107,.2)}.b.dgr:active{background:rgba(232,107,107,.08)}
.b.dis{opacity:.25;pointer-events:none}
.b.pre{flex:1;justify-content:center;flex-direction:column;padding:8px 6px;gap:1px;line-height:1.3}
.b.pre .pl{font-size:9.5px;font-weight:500}.b.pre .pr{font-size:7.5px;color:var(--tx3)}
.b.pre.act .pr{color:rgba(21,23,28,.5)}
.inp{padding:6px 8px;background:var(--bg);border:1px solid var(--bd);border-radius:3px;color:var(--tx2);font-family:var(--f);font-size:10px;outline:none}
.inp:focus{border-color:var(--gdd);color:var(--tx)}

/* HELP "?" — fixed z-index */
.ht{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;min-width:20px;border-radius:50%;background:var(--bg3);border:1px solid var(--bd);color:var(--tx3);font-size:9px;cursor:pointer;transition:all .2s;font-weight:500;position:relative;z-index:5}
.ht:hover,.ht:active{background:var(--gdbg2);border-color:var(--gdd);color:var(--gd)}
.ht.pulse{animation:hp 2.5s ease infinite}
@keyframes hp{0%,100%{box-shadow:0 0 0 0 rgba(200,167,100,0)}50%{box-shadow:0 0 0 5px rgba(200,167,100,.15)}}

/* Tooltip — ABOVE everything */
.ttb{display:none;position:fixed;background:var(--bg4);border:1px solid var(--bd2);border-radius:5px;padding:12px;font-size:10.5px;line-height:1.65;color:var(--tx2);z-index:9999;box-shadow:0 10px 30px rgba(0,0,0,.6);max-width:300px;pointer-events:auto}
.ttb.open{display:block}
.ttb b{color:var(--tx);font-weight:500}
.ttb .tl{color:var(--gd);cursor:pointer;font-size:9px;display:inline-flex;align-items:center;gap:3px;margin-top:6px}
.ttb .tl:active{color:var(--gdh)}

/* Nudge */
.ndg{background:var(--gdbg);border:1px solid rgba(200,167,100,.12);border-radius:4px;padding:8px 10px;font-size:10px;line-height:1.5;color:var(--tx2);margin-top:6px;display:none}
.ndg.open{display:block}
.ndg strong{color:var(--gd);font-weight:500}
.ndg .na{color:var(--gd);cursor:pointer;font-size:9px;margin-top:3px;display:inline-block}
.chk{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--tx2);margin-top:6px;cursor:pointer;padding:4px 0}
.chk input{accent-color:var(--gd);width:14px;height:14px;cursor:pointer}

/* Analysis */
.rc{background:var(--bg);border-radius:5px;padding:11px;border:1px solid var(--bd);margin-bottom:6px}
.rd{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.rv{font-size:24px;font-weight:500;color:var(--gd);font-family:var(--se)}
.rdm{font-size:9px;color:var(--tx3)}
.mr{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--bd)}.mr:last-child{border-bottom:none}
.mn{font-size:11px;font-weight:500}.mt{font-size:8.5px;color:var(--tx3);margin-left:5px}
.bg{padding:2px 7px;border-radius:2px;font-size:9px;font-weight:500}
.bg-f{background:rgba(91,212,164,.1);color:var(--gn);border:1px solid rgba(91,212,164,.18)}
.bg-p{background:rgba(234,179,8,.1);color:#DAB220;border:1px solid rgba(234,179,8,.18)}
.bg-w{background:rgba(232,148,74,.1);color:var(--or);border:1px solid rgba(232,148,74,.18)}
.bg-n{background:rgba(232,107,107,.1);color:var(--rd);border:1px solid rgba(232,107,107,.18)}
.ar{display:flex;gap:3px;margin-bottom:3px}
.ab{flex:1;min-height:38px;padding:6px 4px;background:var(--bg3);border:1px solid var(--bd);border-radius:3px;color:var(--tx2);font-size:9px;font-family:var(--f);cursor:pointer;transition:all .12s;text-align:center;display:flex;align-items:center;justify-content:center}
.ab:active{border-color:var(--gdd);color:var(--gd)}
input[type=range]{-webkit-appearance:none;width:100%;height:3px;background:var(--bd);border-radius:2px;outline:none;margin-top:4px}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--gd);cursor:pointer;border:3px solid var(--bg)}

/* CANVAS */
#cw{flex:1;position:relative;overflow:hidden;background:var(--bg);background-image:radial-gradient(ellipse at 15% 50%,rgba(200,167,100,.008) 0%,transparent 60%)}
#cv{display:block;touch-action:none}
.tb{position:absolute;top:8px;left:8px;display:flex;gap:3px;z-index:10}
.tb .b{background:rgba(26,29,34,.92);backdrop-filter:blur(6px);min-height:40px;min-width:40px;justify-content:center}
#zi{position:absolute;bottom:8px;left:8px;font-size:9px;color:rgba(255,255,255,.75);z-index:10;background:rgba(21,23,28,.85);padding:4px 10px;border-radius:3px;border:1px solid var(--bd);letter-spacing:.5px}
#credit{position:absolute;bottom:8px;right:12px;font-size:8px;color:#C8A764;letter-spacing:1.5px;z-index:5;opacity:.7}

/* CTX GUIDE */
#cg{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;z-index:5;transition:opacity .4s}
#cg.hid{opacity:0}
.gs{font-size:9px;color:rgba(255,255,255,.7);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:8px;text-shadow:0 1px 4px rgba(0,0,0,.8)}
.gi{font-size:44px;color:rgba(255,255,255,.3);margin-bottom:10px;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.gt{font-size:16px;color:#fff;font-weight:600;font-family:var(--se);letter-spacing:.5px;text-shadow:0 1px 6px rgba(0,0,0,.9)}
.gu{font-size:11px;color:rgba(255,255,255,.55);margin-top:5px;text-shadow:0 1px 3px rgba(0,0,0,.8)}
.gb{pointer-events:all;margin-top:14px}

/* CHAT */
#cp{position:absolute;right:0;top:0;bottom:0;width:360px;background:var(--bg2);border-left:1px solid var(--bd);display:none;flex-direction:column;z-index:60}
#cp.open{display:flex}
#ch{padding:11px 14px;border-bottom:1px solid var(--bd);display:flex;justify-content:space-between;align-items:center}
#ch span{font-weight:500;font-size:11px;color:var(--gd)}
#cc{background:none;border:none;color:var(--tx3);cursor:pointer;font-size:18px;font-family:var(--f);padding:4px 8px;min-height:var(--tm);display:flex;align-items:center}
#cm{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:6px;-webkit-overflow-scrolling:touch}
.cb{max-width:88%;padding:8px 11px;border-radius:6px;font-size:11px;line-height:1.6;white-space:pre-wrap;word-break:break-word}
.cb.u{align-self:flex-end;background:var(--gdbg2);border:1px solid rgba(200,167,100,.18)}
.cb.a{align-self:flex-start;background:var(--bg3);border:1px solid var(--bd)}
.cb.t{align-self:flex-start;background:rgba(91,212,164,.08);border:1px solid rgba(91,212,164,.18)}
.cb-tag{display:inline-block;font-size:8px;font-weight:700;color:var(--gn);letter-spacing:1.5px;margin-bottom:3px;text-transform:uppercase}
#ci{padding:8px 12px;border-top:1px solid var(--bd);display:flex;gap:5px}
#ct{flex:1;padding:10px;background:var(--bg);border:1px solid var(--bd);border-radius:4px;color:var(--tx);font-family:var(--f);font-size:11px;outline:none;min-height:var(--tm)}
#ct:focus{border-color:var(--gdd)}
.ctyp{color:var(--gdd);font-size:10px;text-align:center;padding:8px;letter-spacing:1px}
.ctyp::after{content:'';animation:dots 1.5s steps(4) infinite}
@keyframes dots{0%{content:''}25%{content:'.'}50%{content:'..'}75%{content:'...'}}

/* RIGHT ANALYSIS PANEL */
#rbar{position:fixed;right:0;top:0;height:100%;width:320px;background:var(--bg2);border-left:1px solid var(--bd);z-index:55;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1)}
#rbar.rbar-closed{transform:translateX(100%)}
#rbar.rbar-open{transform:translateX(0)}
.rtog{position:absolute;left:-36px;top:50%;transform:translateY(-50%);background:var(--bg2);border:1px solid var(--bd);border-right:none;color:var(--gd);font-size:10px;padding:8px 6px;cursor:pointer;border-radius:4px 0 0 4px;writing-mode:vertical-lr;text-orientation:mixed;letter-spacing:1px;z-index:56}
.rtog:hover{background:var(--bg3)}
#rContent{flex:1;overflow-y:auto;padding:0 10px 10px}
.rtabs{display:flex;border-bottom:1px solid var(--bd);position:sticky;top:0;background:var(--bg2);z-index:2;padding:8px 0 0}
.rtab{flex:1;padding:7px 4px;font-size:9px;letter-spacing:.5px;text-transform:uppercase;background:none;border:none;border-bottom:2px solid transparent;color:var(--tx3);cursor:pointer;transition:all .2s}
.rtab.act{color:var(--gd);border-bottom-color:var(--gd)}
.rtab:hover{color:var(--tx)}
.rpane{display:none;padding-top:8px}
.rpane.act{display:block}
.rEmpty{color:var(--tx4);font-size:10px;text-align:center;padding:30px 10px;line-height:1.6}
/* Object rows in project/conjunto tabs */
.oRow{display:flex;align-items:center;gap:6px;padding:5px 6px;border-radius:3px;cursor:pointer;font-size:10px;transition:background .15s}
.oRow:hover{background:var(--bg3)}
.oRow.oSel{background:rgba(200,167,100,.08)}
.oSwatch{width:10px;height:10px;border-radius:2px;flex-shrink:0}
.oLabel{flex:1;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.oRatio{color:var(--tx);font-weight:500;font-family:var(--mo)}
.oBadge{font-size:8px;padding:1px 5px;border-radius:3px;font-weight:500}
.oChk{width:14px;height:14px;accent-color:var(--gd);cursor:pointer;flex-shrink:0}
/* Conjunction results */
.cjPair{padding:6px 8px;border:1px solid var(--bd);border-radius:4px;margin-bottom:5px;font-size:10px;line-height:1.5}
.cjPair .cjTitle{font-weight:500;color:var(--tx);margin-bottom:2px}
.cjPair .cjDev{font-size:9px}
.cjCoherent{color:#5BD4A4}.cjDivergent{color:#E86B6B}.cjPartial{color:#E8944A}
/* Scale + Insights */
.scaleBox{padding:6px 0;border-bottom:1px solid var(--bd);margin-bottom:6px}
.scIn{width:52px;background:var(--bg3);border:1px solid var(--bd);color:var(--tx);border-radius:3px;padding:3px 5px;font-size:10px}
.insightBox{background:linear-gradient(135deg,rgba(200,167,100,.06),rgba(91,212,164,.06));border:1px solid rgba(200,167,100,.15);border-radius:5px;padding:10px;margin:6px 0;font-size:10.5px;line-height:1.65;color:var(--tx2);white-space:pre-line}
.insightBox strong{color:var(--gd)}
.insightBox .insIcon{margin-right:4px}
/* Narrativa automática */
.cjNarr{background:var(--bg3);border:1px solid var(--bd);border-radius:5px;padding:8px 10px;font-size:10px;line-height:1.7}
.cjNarrLine{margin-bottom:2px}
.cjNarrLine strong{color:var(--tx);font-weight:500}
.cjIcon{font-size:8px;margin-right:2px}
details summary{outline:none;user-select:none}

/* POPUP OVERLAY */
.popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9999;display:flex;align-items:center;justify-content:center}
.projCard{background:var(--bg3);border:1px solid var(--bd);border-radius:6px;padding:10px 12px;margin-bottom:6px;cursor:pointer;transition:border-color .2s}
.projCard:hover{border-color:var(--accent)}
.projCard .pName{font-size:12px;font-weight:500;color:var(--tx)}
.projCard .pMeta{font-size:9px;color:var(--tx3);margin-top:3px}
.projCard .pActions{display:flex;gap:4px;margin-top:6px}

/* RESPONSIVE */
@media(max-width:900px){:root{--sb:270px}#cp{width:320px}#rbar{width:280px}}
@media(max-width:640px){:root{--sb:100vw}#sidebar{position:fixed;height:100%;left:0;top:0}#sidebar.collapsed{transform:translateX(-100%)}#cp{width:100%}#rbar{width:100%}}
@media(min-width:1400px){:root{--sb:340px}#rbar{width:360px}}