/* igo — dark green terminal browser */
:root{
  --bg:#0a0f0a; --panel:#0f160f; --panel-2:#111c12;
  --text:#bfe8c8; --dim:#6f9a78; --line:#1c2a1d;
  --accent:#27d07a; --accent2:#0b5d36; --danger:#e0533b;
  --radius:6px; --speed:.18s;
  --ease:cubic-bezier(.22,.61,.36,1);      /* buttery deceleration */
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;overflow:hidden;background:var(--bg);color:var(--text);
  font:13px/1.5 ui-monospace,"SF Mono","Cascadia Code","Consolas",monospace}
.flat *{transition:none!important;animation:none!important}
button{font:inherit;color:inherit;cursor:pointer}
input,select{font:inherit;color:var(--text)}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* subtle scanline texture so it isn't a flat AI gradient */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.025;
  background:repeating-linear-gradient(0deg,#fff 0 1px,transparent 1px 3px)}

/* ---------- boot ---------- */
#boot{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:var(--bg);transition:opacity .35s ease}
#boot.gone{opacity:0;pointer-events:none}
.boot-inner{width:320px;max-width:84vw}
.boot-mark{color:var(--accent);text-align:center;filter:drop-shadow(0 0 6px rgba(39,208,122,.4))}
.boot-name{text-align:center;font-size:26px;letter-spacing:6px;color:var(--accent);margin:10px 0 22px;
  text-shadow:0 0 8px rgba(39,208,122,.5)}
.boot-bar{height:2px;background:var(--line);overflow:hidden}
.boot-bar i{display:block;height:100%;width:0;transition:width .3s var(--ease);
  background:linear-gradient(90deg,var(--accent2),var(--accent),var(--accent2));background-size:200% 100%;
  animation:shimmer 1.1s linear infinite;box-shadow:0 0 8px var(--accent)}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.boot-log{margin-top:14px;font-size:11px;color:var(--dim);min-height:120px}
.boot-log div{opacity:0;animation:logIn .25s forwards}
.boot-log b{color:var(--accent)}
@keyframes logIn{to{opacity:1}}

/* ---------- app ---------- */
#app{display:none;flex-direction:column;height:100%}
#app.up{display:flex}

/* tab strip */
.chrome{display:flex;align-items:stretch;gap:1px;background:#070b07;padding:6px 6px 0;border-bottom:1px solid var(--line)}
.tabs{display:flex;gap:1px;flex:1;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{display:flex;align-items:center;gap:8px;height:30px;padding:0 8px 0 11px;min-width:120px;max-width:200px;
  background:var(--panel);border:1px solid var(--line);border-bottom:none;color:var(--dim);position:relative;
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  transition:background var(--speed) var(--ease),color var(--speed) var(--ease),max-width .25s var(--ease),padding .25s var(--ease),opacity .2s;
  animation:tabIn .28s var(--ease-spring) both}
@keyframes tabIn{from{opacity:0;transform:translateY(7px) scale(.97);max-width:0}}
.tab.closing{max-width:0!important;min-width:0!important;padding:0!important;opacity:0;overflow:hidden}
.tab:hover{color:var(--text)}
.tab.on{background:var(--panel-2);color:var(--text);border-color:var(--accent2)}
.tab.on::before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--accent);box-shadow:0 0 6px var(--accent)}
.tab .fav{width:14px;height:14px;flex:none;border-radius:2px;background:var(--line)}
.tab .ttl{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px}
.tab .c{opacity:.45;padding:0 2px;font-size:15px;line-height:1}
.tab .c:hover{opacity:1;color:var(--danger)}
.t-new{width:30px;background:var(--panel);border:1px solid var(--line);border-bottom:none;color:var(--accent);
  font-size:18px;line-height:1}
.t-new:hover{background:var(--panel-2)}

/* toolbar */
.bar{display:flex;align-items:center;gap:5px;padding:6px;background:var(--panel);border-bottom:1px solid var(--line)}
.nav{width:30px;height:30px;background:transparent;border:1px solid transparent;border-radius:var(--radius);
  font-size:15px;display:flex;align-items:center;justify-content:center;
  transition:background var(--speed) var(--ease),border-color var(--speed) var(--ease),transform .12s var(--ease-spring)}
.nav:hover{background:var(--panel-2);border-color:var(--line)}
.nav:active{transform:scale(.88)}
.nav.act{color:var(--accent);border-color:var(--accent2)}
.addr{flex:1;display:flex;align-items:center;gap:8px;height:30px;padding:0 10px;background:#070b07;
  border:1px solid var(--line);border-radius:var(--radius)}
.addr:focus-within{border-color:var(--accent2)}
.addr.private{border-color:var(--accent)}
.lock{color:var(--dim);font-size:12px}
.addr.private .lock{color:var(--accent)}
#url{flex:1;background:transparent;border:none;outline:none;font-size:12.5px}
#url::placeholder{color:var(--dim)}
.spin{width:7px;height:7px;border-radius:50%;flex:none}
.spin.go{background:var(--accent);animation:blink .8s steps(2) infinite;box-shadow:0 0 6px var(--accent)}
@keyframes blink{50%{opacity:.2}}
.eng{height:30px;background:#070b07;border:1px solid var(--line);border-radius:var(--radius);padding:0 6px;font-size:11.5px}
.eng option{background:var(--panel)}

/* view */
.view{flex:1;position:relative;background:#000;overflow:hidden;isolation:isolate}
.frame{position:absolute;inset:0;width:100%;height:100%;max-width:100%;border:0;background:#fff;
  visibility:hidden;opacity:0;z-index:0;transition:opacity .28s var(--ease);will-change:opacity}
.frame.on{visibility:visible;opacity:1;z-index:1}
.home{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:22px;background:var(--bg);visibility:hidden;opacity:0;z-index:0;transition:opacity .28s var(--ease)}
.home.on{visibility:visible;opacity:1;z-index:1}
@keyframes fade{from{opacity:0}}
.home .big{font-size:46px;letter-spacing:10px;color:var(--accent);text-shadow:0 0 14px rgba(39,208,122,.4);
  animation:bigIn .5s var(--ease-spring) both}
@keyframes bigIn{from{opacity:0;transform:translateY(8px) scale(.96)}}
.home .hs{display:flex;width:min(520px,84vw);height:42px;border:1px solid var(--line);background:#070b07;border-radius:var(--radius)}
.home .hs:focus-within{border-color:var(--accent2)}
.home .hs input{flex:1;background:transparent;border:none;outline:none;padding:0 14px;font-size:14px}
.home .links{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;max-width:520px}
.home .links a{padding:6px 12px;color:var(--dim);text-decoration:none;border:1px solid var(--line);border-radius:var(--radius);
  font-size:12px;transition:color var(--speed),border-color var(--speed)}
.home .links a:hover{color:var(--accent);border-color:var(--accent2)}

/* settings sheet */
#sheet{position:fixed;top:0;right:0;height:100%;width:360px;max-width:92vw;z-index:1100;background:var(--panel);
  border-left:1px solid var(--accent2);transform:translateX(101%);transition:transform .3s var(--ease);overflow-y:auto;
  box-shadow:-20px 0 50px rgba(0,0,0,.4)}
#sheet.open{transform:none}
#sheet header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:var(--panel);letter-spacing:3px;color:var(--accent)}
#sheet header .x{background:none;border:none;font-size:22px;color:var(--dim)}
#sheet header .x:hover{color:var(--danger)}
.grp{padding:16px;border-bottom:1px solid var(--line)}
.grp h4{margin:0 0 12px;font-size:11px;letter-spacing:2px;color:var(--dim);text-transform:uppercase}
.r{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:9px 0;font-size:12.5px}
.r input[type=text],.r select{width:56%;height:28px;background:#070b07;border:1px solid var(--line);border-radius:var(--radius);padding:0 8px;font-size:12px}
.r input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}

.themes{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.sw{height:46px;border:1px solid var(--line);border-radius:var(--radius);cursor:pointer;position:relative;
  display:flex;align-items:flex-end;padding:4px;font-size:9px;overflow:hidden;transition:border-color var(--speed)}
.sw:hover{border-color:var(--accent2)}
.sw.sel{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}
.sw .nm{position:relative;z-index:1;color:#fff;text-shadow:0 1px 2px #000}
.sw .d{position:absolute;top:2px;right:3px;z-index:2;color:#fff;font-size:13px;opacity:.7}
.sw .d:hover{color:var(--danger);opacity:1}

.mk{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:10px}
.mk label{display:flex;flex-direction:column;gap:3px;font-size:9px;color:var(--dim);text-align:center}
.mk input[type=color]{width:100%;height:26px;border:1px solid var(--line);border-radius:4px;background:none;padding:0;cursor:pointer}
.mk-row{display:flex;gap:6px}
.mk-row input{flex:1;height:30px;background:#070b07;border:1px solid var(--line);border-radius:var(--radius);padding:0 8px;font-size:12px}
.mk-row button,.wide{height:30px;padding:0 12px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--radius);
  font-size:12px;color:var(--text);transition:border-color var(--speed)}
.mk-row button:hover,.wide:hover{border-color:var(--accent2)}
.mk-row button.primary{background:var(--accent2);border-color:var(--accent);color:#dfffea}
.wide{width:100%;margin-top:6px}
.wide:hover{border-color:var(--danger);color:var(--danger)}

.dstats{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}
.st{padding:8px;background:#070b07;border:1px solid var(--line);border-radius:var(--radius)}
.st b{display:block;color:var(--accent);font-size:15px}
.st small{color:var(--dim);font-size:10px}
.dlog{margin-top:10px;background:#070b07;border:1px solid var(--line);border-radius:var(--radius);padding:8px;
  font-size:10.5px;max-height:160px;overflow:auto;white-space:pre-wrap;word-break:break-word;color:var(--dim)}
.dlog .e{color:var(--danger)}.dlog .k{color:var(--accent)}.dlog .w{color:#d9b34a}

#scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1050;opacity:0;pointer-events:none;transition:opacity .25s}
#scrim.show{opacity:1;pointer-events:auto}
