/* Sophia — hi-fi component styles (atoms + shell + views) */

/* ---------- atoms ---------- */
.sev-badge{font-size:10px;font-weight:600;letter-spacing:.06em;color:#fff;padding:3px 8px;border-radius:5px;white-space:nowrap;display:inline-block;}
.mode-tag{font-size:9px;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:20px;white-space:nowrap;}
.mode-tag.c{background:var(--accent);color:var(--on-accent);font-weight:600;}
.mode-tag.m{border:1px solid var(--line-mid);color:var(--t-lo);}
.src{font-size:10px;color:var(--t-mid);border:1px solid var(--line-mid);border-radius:4px;padding:2px 7px;letter-spacing:.04em;white-space:nowrap;}
.chip{font-size:11px;color:var(--t-mid);border:1px solid var(--line-mid);border-radius:20px;padding:4px 11px;cursor:pointer;transition:.14s;white-space:nowrap;user-select:none;}
.chip:hover{border-color:var(--line-bright);color:var(--t-hi);}
.chip.active{background:var(--accent);color:var(--on-accent);border-color:transparent;font-weight:500;}
.btn{font-family:var(--sans);font-size:13px;font-weight:500;border-radius:var(--r-sm);padding:8px 14px;border:1px solid var(--line-mid);background:var(--elevated);color:var(--t-hi);cursor:pointer;transition:.14s;white-space:nowrap;display:inline-flex;align-items:center;gap:7px;}
.btn:hover{background:var(--hover);border-color:var(--line-bright);}
.btn.pri{background:var(--accent);color:var(--on-accent);border-color:transparent;font-weight:600;}
.btn.pri:hover{box-shadow:0 0 18px var(--accent-glow);}
.btn.ghost{background:transparent;}
.btn.sm{font-size:12px;padding:5px 10px;}
.scorebar{border-radius:4px;background:var(--elevated);overflow:hidden;width:100%;}
.scorebar>i{display:block;height:100%;border-radius:4px;transition:width .5s cubic-bezier(.2,.7,.2,1);}

/* tile */
.tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;min-height:0;position:relative;box-shadow:var(--sh-1);transition:border-color .15s,box-shadow .15s;}
.tile.editing{border-style:dashed;border-color:var(--line-bright);}
.tile.editing:hover{box-shadow:var(--sh-2);}
.tile-h{display:flex;align-items:center;gap:9px;padding:10px 13px;border-bottom:1px solid var(--line);flex-shrink:0;}
.tile-h .grip{color:var(--t-faint);letter-spacing:-2px;font-size:12px;cursor:grab;}
.tile-t{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--t-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tile-r{margin-left:auto;color:var(--t-faint);font-size:12px;display:flex;align-items:center;gap:8px;}
.tile-r .exp{cursor:pointer;}.tile-r .exp:hover{color:var(--t-hi);}
.tile-b{flex:1;min-height:0;display:flex;flex-direction:column;overflow:auto;}
.tile .resize{position:absolute;right:3px;bottom:2px;color:var(--line-bright);font-size:11px;}

.dimbars{display:flex;flex-direction:column;gap:7px;width:100%;}
.dimrow{display:flex;align-items:center;gap:10px;}
.dimlbl{font-size:11px;color:var(--t-mid);width:78px;flex-shrink:0;}
.dimval{font-size:11px;color:var(--t-lo);width:22px;text-align:right;}
.dev-flag{position:absolute;top:4px;right:6px;font-size:9px;color:var(--crit);background:var(--crit-fill);border:1px solid var(--crit-line);border-radius:4px;padding:2px 6px;letter-spacing:.04em;}
.fc-legend{display:flex;gap:14px;margin-top:8px;}
.fc-legend span{display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--t-lo);}
.fc-legend i{width:12px;height:8px;border-radius:2px;display:inline-block;}

/* ---------- app frame ---------- */
.app{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--void);}
.app-top{height:var(--top-h);flex-shrink:0;display:flex;align-items:center;gap:16px;padding:0 16px;background:var(--deep);border-bottom:1px solid var(--line-mid);z-index:30;}
.app-body{flex:1;display:flex;min-height:0;}

/* rail */
.rail{width:var(--rail-w);flex-shrink:0;background:var(--deep);border-right:1px solid var(--line-mid);display:flex;flex-direction:column;align-items:center;padding:11px 0 12px;gap:3px;z-index:20;}
.rail .brand{width:42px;height:42px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;flex-shrink:0;color:var(--accent);}
.rail .brand svg{width:34px;height:34px;}
.nav-i{width:50px;padding:8px 0;border-radius:var(--r-md);display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;color:var(--t-lo);transition:.14s;position:relative;}
.nav-i:hover{color:var(--t-mid);background:var(--surface);}
.nav-i.on{color:var(--accent);background:var(--accent-glow);}
.nav-i.on::before{content:"";position:absolute;left:-11px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:3px;background:var(--accent);box-shadow:0 0 8px var(--accent);}
.nav-i svg{width:19px;height:19px;}
.nav-i .nl{font-size:8.5px;letter-spacing:.04em;text-transform:uppercase;font-weight:600;}
.rail .sp{flex:1;}

/* topbar bits */
.crumb{display:flex;align-items:center;gap:9px;font-weight:600;font-size:14.5px;white-space:nowrap;flex-shrink:0;}
.crumb .c-sub{color:var(--t-lo);font-weight:400;}
.crumb .c-chev{color:var(--t-faint);}
.gsearch{flex:0 1 360px;height:32px;border:1px solid var(--line-mid);border-radius:var(--r-sm);background:var(--surface);display:flex;align-items:center;gap:9px;padding:0 11px;color:var(--t-lo);font-size:13px;cursor:text;transition:.14s;white-space:nowrap;overflow:hidden;}
.gsearch:hover{border-color:var(--line-bright);}
.gsearch span{overflow:hidden;text-overflow:ellipsis;}
.gsearch .k{margin-left:auto;font-size:10px;border:1px solid var(--line-mid);border-radius:4px;padding:1px 5px;flex-shrink:0;}
.top-r{margin-left:auto;display:flex;align-items:center;gap:10px;}
.statpill{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--t-mid);border:1px solid var(--line-mid);border-radius:20px;padding:4px 11px;white-space:nowrap;}
.livedot{width:8px;height:8px;border-radius:50%;background:var(--crit);animation:sph-ring 1.8s infinite;}
.avatar{width:30px;height:30px;border-radius:50%;border:1px solid var(--line-bright);background:var(--panel);display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600;color:var(--t-hi);cursor:pointer;}

/* view scaffolding */
.view{flex:1;min-height:0;display:flex;flex-direction:column;}
.view-bar{height:46px;flex-shrink:0;display:flex;align-items:center;gap:12px;padding:0 18px;border-bottom:1px solid var(--line);background:var(--deep);white-space:nowrap;}
.view-bar .vb-title{font-size:14px;font-weight:600;}
.seg{display:flex;gap:2px;background:var(--surface);border:1px solid var(--line-mid);border-radius:var(--r-sm);padding:2px;}
.vb-title{white-space:nowrap;}
.lockchip{white-space:nowrap;}
.seg span{font-size:12px;font-weight:500;padding:5px 13px;border-radius:5px;cursor:pointer;color:var(--t-mid);transition:.12s;}
.seg span:hover{color:var(--t-hi);}
.seg span.on{background:var(--accent);color:var(--on-accent);font-weight:600;}

/* ---------- Workspace ---------- */
.ws-grid{flex:1;overflow:auto;padding:16px;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:152px;gap:14px;align-content:start;}
.ws-lib{width:226px;flex-shrink:0;border-left:1px solid var(--line-mid);background:var(--deep);display:flex;flex-direction:column;}
.lib-h{padding:13px 15px;border-bottom:1px solid var(--line);}
.lib-list{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column;gap:8px;}
.lib-i{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line-mid);border-radius:var(--r-sm);padding:9px 11px;font-size:12.5px;color:var(--t-mid);cursor:grab;transition:.14s;}
.lib-i:hover{border-color:var(--accent-dim);color:var(--t-hi);background:var(--panel);}
.lib-i .g{color:var(--t-faint);letter-spacing:-2px;}
.dropzone{grid-column:span 1;border:1.5px dashed var(--line-bright);border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;color:var(--t-lo);font-size:12.5px;gap:7px;background:rgba(56,210,240,0.03);}

.wlist{display:flex;flex-direction:column;}
.wrow{display:grid;grid-template-columns:auto 1fr auto;gap:11px;align-items:center;padding:9px 13px;border-bottom:1px solid var(--line);cursor:pointer;transition:.12s;}
.wrow:last-child{border-bottom:0;}
.wrow:hover{background:var(--panel);}
.wrow .st{width:3px;height:30px;border-radius:3px;}
.wrow .we{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.wrow .wf{font-size:11.5px;color:var(--t-mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

.gaugebig{font-size:46px;font-weight:600;line-height:1;}
.moverrow{display:flex;align-items:center;gap:9px;padding:7px 0;border-bottom:1px solid var(--line);}
.moverrow:last-child{border-bottom:0;}

/* ---------- Explore ---------- */
.exp-wrap{flex:1;display:flex;min-height:0;}
.exp-pane{flex:1;position:relative;min-width:0;overflow:hidden;}
.exp-pane.geo{border-right:1px solid var(--line-mid);background:#070b11;}
.map-root{position:absolute;inset:0;}
.canvas-fallback{position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,#141d28,#070b11);}
.pane-tag{position:absolute;top:10px;left:13px;z-index:5;}
.float{position:absolute;background:rgba(14,22,38,0.9);backdrop-filter:blur(8px);border:1px solid var(--line-mid);border-radius:var(--r-md);box-shadow:var(--sh-2);}
.layers{left:13px;bottom:13px;padding:11px 13px;min-width:172px;}
.layers .lrow{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--t-mid);margin:4px 0;cursor:pointer;white-space:nowrap;}
.layers .lbox{width:13px;height:13px;border:1px solid var(--line-bright);border-radius:3px;flex-shrink:0;}
.layers .lbox.on{background:var(--accent);border-color:transparent;}
.glegend{right:13px;bottom:13px;padding:10px 13px;min-width:172px;white-space:nowrap;}

.graph-svg{position:absolute;inset:0;width:100%;height:100%;}
.gnode{position:absolute;transform:translate(-50%,-50%);text-align:center;cursor:pointer;z-index:3;transition:.15s;}
.gnode .gn-dot{border-radius:50%;margin:0 auto;border:2px solid rgba(0,0,0,.35);transition:.15s;}
.gnode .gn-l{font-size:10.5px;color:var(--t-mid);margin-top:5px;max-width:104px;line-height:1.15;}
.gnode.hub .gn-l{font-size:12px;color:var(--t-hi);font-weight:600;}
.gnode.sel .gn-dot{box-shadow:0 0 0 5px var(--accent-glow),0 0 16px currentColor;}
.gnode:hover .gn-dot{transform:scale(1.12);}
.gn-flag{position:absolute;top:-17px;left:50%;transform:translateX(-50%);font-size:8px;color:#fff;background:var(--high);border-radius:3px;padding:1px 5px;white-space:nowrap;letter-spacing:.04em;}

/* entity drawer (small pane that escalates) */
.drawer{width:340px;height:100%;flex-shrink:0;background:var(--deep);border-left:1px solid var(--line-mid);display:flex;flex-direction:column;}
.drawer-dock{position:fixed;top:var(--top-h);right:0;bottom:0;z-index:50;box-shadow:var(--sh-3);}
.drawer-dock.full{top:0;left:0;background:rgba(6,10,19,0.6);backdrop-filter:blur(3px);}
.drawer-dock.full .drawer{width:min(900px,100vw);margin-left:auto;border-left:1px solid var(--line-mid);}
.geo-ent:hover{transform:scale(1.35)!important;}
.dh{padding:15px 17px;border-bottom:1px solid var(--line);}
.db{flex:1;overflow:auto;padding:16px 17px;display:flex;flex-direction:column;gap:16px;}
.sectit{display:flex;align-items:center;margin-bottom:9px;}
.geo-marker{position:absolute;transform:translate(-50%,-50%);text-align:center;z-index:6;pointer-events:none;}

/* ---------- Exec ---------- */
.exec-scroll{flex:1;overflow:auto;padding:24px 30px;}
.exec-grid{display:grid;grid-template-columns:1.05fr 1.5fr 1fr;gap:18px;max-width:1320px;margin:0 auto;}
.exec-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--sh-1);}
.exec-foot{max-width:1320px;margin:22px auto 0;border-top:1px solid var(--line);padding-top:16px;font-size:12px;color:var(--t-lo);}
.lockchip{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--t-mid);border:1px solid var(--line-mid);border-radius:20px;padding:4px 11px;}
.critline{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--line);}
.critline:last-child{border-bottom:0;}
