/* computer-95 system overlays */
.c95-mask{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:99998;display:none;align-items:center;justify-content:center;font-family:var(--sg)}
.c95-mask.show{display:flex}
.c95-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:28px 26px;width:380px;max-width:calc(100vw - 24px);position:relative;overflow:hidden}
.c95-card::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--g);opacity:.7}
.c95-card h1{font-size:18px;letter-spacing:.02em;margin-bottom:6px;color:var(--white)}
.c95-card .sub{font-family:var(--jb);font-size:11px;color:var(--sub);margin-bottom:18px;letter-spacing:.08em;text-transform:uppercase}
.c95-card label{display:block;font-family:var(--jb);font-size:10px;color:var(--sub);text-transform:uppercase;letter-spacing:.1em;margin:10px 0 4px}
.c95-card input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--white);padding:10px 12px;border-radius:6px;font:inherit;outline:none}
.c95-card input:focus{border-color:#444}
.c95-card button{width:100%;margin-top:14px;padding:10px;background:var(--white);color:#000;border:none;border-radius:6px;font-family:var(--sg);font-weight:600;font-size:13px;cursor:pointer}
.c95-card button:disabled{opacity:.5;cursor:wait}
.c95-card button.secondary{background:transparent;color:var(--sub);font-weight:500;font-size:12px;margin-top:8px}
.c95-card .err{color:#e74c3c;font-size:12px;font-family:var(--jb);margin-top:8px;min-height:14px}
.c95-card .toggle{font-family:var(--jb);font-size:11px;color:var(--sub);margin-top:14px;text-align:center;cursor:pointer}
.c95-card .toggle:hover{color:var(--white)}
.c95-tabs{display:flex;gap:4px;margin:14px 0 4px;border-bottom:1px solid var(--border)}
.c95-tabs button{flex:1;background:transparent;border:none;color:var(--sub);padding:8px 4px;font:11px var(--jb);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.c95-tabs button.on{color:var(--white);border-bottom-color:var(--white)}
.c95-tabs button:hover{color:var(--white)}

.c95-toast{position:fixed;right:14px;bottom:60px;z-index:99997;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.c95-toast .t{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--white);font-size:13px;min-width:240px;max-width:340px;position:relative;overflow:hidden;pointer-events:auto;animation:c95slide .25s ease-out}
.c95-toast .t::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--g);opacity:.7}
.c95-toast .t .src{font-family:var(--jb);font-size:9px;color:var(--sub);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2px}
@keyframes c95slide{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

/* Files app */
.fx-root{display:flex;flex-direction:column;height:100%;font-family:var(--sg);color:var(--text)}
.fx-bar{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid var(--border);font-family:var(--jb);font-size:11px;color:var(--sub)}
.fx-bar input{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--white);padding:5px 8px;border-radius:4px;font:inherit}
.fx-bar button{background:var(--elevated);border:1px solid var(--border);color:var(--white);padding:4px 10px;border-radius:4px;font-family:var(--jb);font-size:10px;cursor:pointer}
.fx-bar button:hover{background:var(--hover)}
.fx-list{flex:1;overflow:auto;padding:6px 4px;font-size:13px}
.fx-row{display:grid;grid-template-columns:18px 1fr 90px 140px;gap:8px;padding:5px 10px;cursor:pointer;border-radius:4px;align-items:center}
.fx-row:hover{background:var(--hover)}
.fx-row.dir{color:var(--white)}
.fx-row .ico{font-family:var(--jb);font-size:11px;color:var(--sub)}
.fx-row .sz,.fx-row .mt{font-family:var(--jb);font-size:10px;color:var(--sub);text-align:right}
.fx-empty{padding:30px;color:var(--sub);font-size:12px;text-align:center}
.fx-drop{position:absolute;inset:0;background:rgba(0,0,0,.7);border:2px dashed var(--white);display:none;align-items:center;justify-content:center;color:var(--white);font-family:var(--jb);font-size:13px;pointer-events:none}
.fx-drop.on{display:flex}

/* Notes app */
.nt-root{display:grid;grid-template-columns:200px 1fr;height:100%;font-family:var(--sg);color:var(--text)}
.nt-side{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.nt-side .hd{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border);font-family:var(--jb);font-size:10px;color:var(--sub);text-transform:uppercase;letter-spacing:.1em}
.nt-side .hd button{background:none;border:none;color:var(--white);cursor:pointer;font-size:16px;line-height:1}
.nt-list{flex:1;overflow:auto}
.nt-item{padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer}
.nt-item:hover{background:var(--hover)}
.nt-item.active{background:var(--hover)}
.nt-item .ti{font-size:13px;color:var(--white);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nt-item .pv{font-family:var(--jb);font-size:10px;color:var(--sub);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nt-edit{display:flex;flex-direction:column;height:100%}
.nt-edit input.title{background:transparent;border:none;color:var(--white);font:600 16px var(--sg);padding:14px 16px 4px;outline:none}
.nt-edit textarea{flex:1;background:transparent;border:none;color:var(--text);font:13px/1.5 var(--jb);padding:8px 16px 16px;outline:none;resize:none}
.nt-status{padding:4px 16px;font-family:var(--jb);font-size:9px;color:var(--sub);text-transform:uppercase;letter-spacing:.1em;border-top:1px solid var(--border)}
.nt-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--sub);font-size:12px}

/* Terminal */
.term-root{display:flex;flex-direction:column;height:100%;background:#000;font-family:var(--jb);font-size:12px;color:#bbb}
.term-out{flex:1;overflow:auto;padding:10px 12px;white-space:pre-wrap;word-break:break-word}
.term-out .pr{color:#888}
.term-out .me{color:#fff}
.term-line{display:flex;align-items:center;gap:6px;padding:6px 12px;border-top:1px solid var(--border)}
.term-line .pr{color:#888}
.term-line input{flex:1;background:transparent;border:none;color:#fff;font:inherit;outline:none;caret-color:#fff}

/* Browser */
.bw-root{display:flex;flex-direction:column;height:100%;background:#000}
.bw-bar{display:flex;align-items:center;gap:6px;padding:6px;border-bottom:1px solid var(--border)}
.bw-bar button{background:var(--elevated);border:1px solid var(--border);color:var(--white);padding:4px 10px;border-radius:4px;font-family:var(--jb);font-size:11px;cursor:pointer}
.bw-bar input{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--white);padding:6px 10px;border-radius:4px;font:inherit;outline:none}
.bw-frame{flex:1;border:none;background:#fff;width:100%}

/* User chip in taskbar */
.c95-user{display:inline-flex;align-items:center;gap:6px;padding:0 10px;font-family:var(--jb);font-size:10px;color:var(--white);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;border-left:1px solid var(--border)}
.c95-user .av{width:18px;height:18px;border-radius:50%;background:var(--g);background-size:200% 100%;animation:gradPulse 8s ease-in-out infinite}
.c95-user .nm{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
