@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600&display=swap');

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

:root{
  --bg:#1e1e2e;
  --mantle:#181825;
  --crust:#11111b;
  --surface0:#313244;
  --surface1:#45475a;
  --surface2:#585b70;
  --overlay0:#6c7086;
  --overlay1:#7f849c;
  --text:#cdd6f4;
  --subtext:#a6adc8;
  --subtext0:#bac2de;
  --mauve:#cba6f7;
  --peach:#fab387;
  --yellow:#f9e2af;
  --green:#a6e3a1;
  --teal:#94e2d5;
  --sapphire:#74c7ec;
  --blue:#89b4fa;
  --lavender:#b4befe;
  --mono:'JetBrains Mono',monospace;
}

html,body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--mono);
  font-size:13px;
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
}

/* ─── TABLINE ─────────────────────────────────── */
.tabline{
  position:sticky;top:0;left:0;right:0;height:32px;
  background:var(--crust);display:flex;align-items:stretch;
  border-bottom:1px solid var(--surface0);z-index:99;
  overflow-x:auto;
}
.tab{
  padding:0 18px;display:flex;align-items:center;gap:7px;
  border-right:1px solid var(--surface0);cursor:pointer;
  color:var(--overlay1);font-size:11px;white-space:nowrap;
  transition:background .15s,color .15s;position:relative;
  user-select:none;
}
.tab:hover{background:var(--surface0);color:var(--subtext)}
.tab.active{background:var(--bg);color:var(--text)}
.tab.active::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:1px;background:var(--mauve);
}
.tab-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.tab-close{color:var(--overlay0);font-size:10px;margin-left:4px;opacity:0;transition:opacity .15s}
.tab:hover .tab-close{opacity:1}
.tab-spacer{flex:1}
.nvim-logo{padding:0 14px;display:flex;align-items:center;color:var(--overlay0);font-size:10px}

/* ─── LAYOUT ──────────────────────────────────── */
.layout{display:flex;min-height:calc(100vh - 54px)}

/* ─── FILETREE ────────────────────────────────── */
.filetree{
  width:220px;min-width:220px;background:var(--mantle);
  border-right:1px solid var(--surface0);padding:8px 0;
  font-size:12px;
}
.ft-header{
  padding:6px 12px;color:var(--overlay0);font-size:10px;
  letter-spacing:1.5px;text-transform:uppercase;margin-bottom:4px;
}
.ft-item{
  padding:3px 12px 3px 20px;color:var(--subtext);cursor:pointer;
  display:flex;align-items:center;gap:7px;
  transition:background .1s,color .1s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  user-select:none;
}
.ft-item:hover{background:var(--surface0);color:var(--text)}
.ft-item.active{background:var(--surface0);color:var(--blue)}
.ft-item.dir{color:var(--blue);padding-left:12px}
.ft-item.dir .ft-icon{color:var(--yellow)}
.ft-icon{width:14px;text-align:center;flex-shrink:0;font-size:11px}
.ft-indent{padding-left:28px}
.ft-section{margin-top:12px}

/* ─── WORDMARK FLICKER ────────────────────────── */
.wordmark-wrap{display:inline-block;position:relative}
.wm-a,.wm-b{display:inline-block;transition:opacity .06s}
.wm-b{
  position:absolute;left:0;top:0;opacity:0;
  color:var(--peach);white-space:nowrap;pointer-events:none;
}

/* ─── EDITOR ──────────────────────────────────── */
.editor{flex:1;overflow-y:auto;padding-bottom:30px}

/* ─── CODE VIEW ───────────────────────────────── */
.code-view{display:flex;font-size:13px}
.line-nums{
  min-width:48px;padding:16px 8px 16px 0;
  text-align:right;color:var(--surface2);
  user-select:none;border-right:1px solid var(--surface0);
  font-size:12px;line-height:1.8;background:var(--bg);
}
.line-num{padding:0 8px;display:block;line-height:1.8}
.line-num.cur{color:var(--text)}
.code-content{flex:1;padding:16px 0 16px 20px;line-height:1.8}

/* ─── SYNTAX HIGHLIGHTING ─────────────────────── */
.c-comment{color:var(--surface2);font-style:italic}
.c-keyword{color:var(--mauve)}
.c-fn{color:var(--blue)}
.c-string{color:var(--green)}
.c-type{color:var(--yellow)}
.c-num{color:var(--peach)}
.c-op{color:var(--teal)}
.c-var{color:var(--text)}
.c-prop{color:var(--lavender)}
.c-ns{color:var(--sapphire)}
.c-punct{color:var(--overlay1)}
.c-heading{color:var(--mauve);font-weight:600}

/* ─── CURSOR ──────────────────────────────────── */
.cursor{
  display:inline-block;width:2px;height:1em;
  background:var(--text);vertical-align:text-bottom;
  animation:blink 1.2s step-end infinite;margin-left:1px;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* ─── LANG PILLS ──────────────────────────────── */
.langs{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0}
.lang-pill{
  padding:2px 10px;border:1px solid var(--surface1);border-radius:2px;
  color:var(--subtext);font-size:11px;transition:all .2s;cursor:default;
}
.lang-pill:hover{border-color:var(--mauve);color:var(--mauve)}
.lang-pill.hi{border-color:rgba(166,227,161,0.4);color:var(--green)}
.lang-pill.hi:hover{border-color:var(--green);color:var(--green)}

/* ─── DIAGNOSTIC ──────────────────────────────── */
.diagnostic{
  display:flex;align-items:center;gap:6px;
  font-size:11px;color:var(--green);margin:8px 0;
}

/* ─── PROJECT CARD ────────────────────────────── */
.project-card{
  border:1px solid var(--surface0);border-radius:4px;
  overflow:hidden;margin:8px 0;transition:border-color .2s;
}
.project-card:hover{border-color:var(--surface1)}

/* ─── VIDEO SLOT ──────────────────────────────── */
.video-slot{
  background:var(--crust);aspect-ratio:16/9;max-height:340px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;border-bottom:1px solid var(--surface0);
  position:relative;overflow:hidden;transition:background .2s;
}
.video-slot:hover{background:var(--mantle)}
.video-inner{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  color:var(--overlay0);transition:color .2s;pointer-events:none;
}
.video-slot:hover .video-inner{color:var(--mauve)}
.play-hex{
  width:44px;height:44px;border:1px solid var(--surface1);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  display:flex;align-items:center;justify-content:center;
  background:var(--surface0);transition:all .2s;
}
.video-slot:hover .play-hex{background:rgba(203,166,247,0.1);border-color:var(--mauve)}
.play-tri{
  width:0;height:0;
  border-top:7px solid transparent;
  border-bottom:7px solid transparent;
  border-left:12px solid var(--overlay1);
  margin-left:3px;transition:border-left-color .2s;
}
.video-slot:hover .play-tri{border-left-color:var(--mauve)}
.vslot-hint{font-size:10px;letter-spacing:.5px}
.vslot-drop{
  position:absolute;bottom:8px;right:10px;
  font-size:9px;color:var(--surface2);pointer-events:none;
}

/* ─── PROJECT META ────────────────────────────── */
.proj-meta{padding:16px 20px}
.proj-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.proj-name{color:var(--blue);font-size:14px;font-weight:500}
.proj-links{display:flex;gap:6px}
.gh-link{
  font-size:10px;padding:3px 10px;border:1px solid var(--surface1);
  border-radius:2px;color:var(--overlay1);text-decoration:none;
  transition:all .2s;display:inline-flex;align-items:center;gap:5px;
}
.gh-link:hover{border-color:var(--green);color:var(--green)}
.proj-desc{color:var(--subtext);font-size:12px;line-height:1.7;margin-bottom:12px}
.proj-tags{display:flex;gap:6px;flex-wrap:wrap}
.ptag{
  font-size:10px;color:var(--peach);
  border:1px solid rgba(250,179,135,.2);
  padding:1px 8px;border-radius:2px;
}

/* ─── CONTACT ─────────────────────────────────── */
.c-input{
  background:transparent;border:none;
  border-bottom:1px solid var(--surface1);outline:none;
  color:var(--green);font-family:var(--mono);
  font-size:13px;padding:2px 4px;
}
.c-textarea{
  background:var(--crust);border:1px solid var(--surface0);
  border-radius:2px;outline:none;color:var(--text);
  font-family:var(--mono);font-size:12px;
  width:100%;padding:8px;resize:vertical;
  margin-bottom:4px;line-height:1.6;
}
.c-btn{
  background:var(--mauve);color:var(--crust);
  border:none;padding:6px 18px;
  font-family:var(--mono);font-size:11px;font-weight:600;
  border-radius:3px;cursor:pointer;transition:opacity .2s;
}
.c-btn:hover{opacity:.8}

/* ─── STATUSLINE ──────────────────────────────── */
.statusline{
  position:fixed;bottom:0;left:0;right:0;height:22px;
  background:var(--mauve);display:flex;align-items:center;
  z-index:100;font-size:11px;font-weight:500;
}
.sl-mode{
  background:var(--crust);color:var(--mauve);
  padding:0 12px;height:100%;display:flex;align-items:center;
  font-weight:600;letter-spacing:.5px;min-width:80px;
}
.sl-branch{
  background:var(--surface0);color:var(--green);
  padding:0 12px;height:100%;display:flex;align-items:center;gap:5px;
}
.sl-file{color:var(--crust);padding:0 12px;flex:1;font-weight:500}
.sl-right{display:flex;align-items:center;height:100%}
.sl-filetype{
  background:var(--surface0);color:var(--blue);
  padding:0 12px;height:100%;display:flex;align-items:center;
}
.sl-pos{
  background:var(--crust);color:var(--mauve);
  padding:0 12px;height:100%;display:flex;align-items:center;
  min-width:52px;
}

/* ─── TELESCOPE ───────────────────────────────── */
.telescope{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  width:560px;background:var(--crust);border:1px solid var(--surface1);
  border-radius:6px;z-index:200;display:none;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
}
.telescope.open{display:block}
.tele-input-wrap{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;border-bottom:1px solid var(--surface0);
}
.tele-prompt{color:var(--mauve);font-size:12px}
.tele-input{
  background:transparent;border:none;outline:none;
  color:var(--text);font-family:var(--mono);font-size:13px;flex:1;
}
.tele-results{max-height:280px;overflow-y:auto}
.tele-item{
  padding:8px 14px;cursor:pointer;display:flex;gap:10px;
  align-items:center;transition:background .1s;font-size:12px;
}
.tele-item:hover,.tele-item.sel{background:var(--surface0)}
.tele-item-icon{color:var(--blue);width:14px;text-align:center}
.tele-item-name{color:var(--text);flex:1}
.tele-item-type{color:var(--overlay0);font-size:10px}
.tele-footer{
  padding:6px 14px;border-top:1px solid var(--surface0);
  display:flex;gap:16px;font-size:10px;color:var(--overlay0);
}
.tele-key{color:var(--mauve)}
.tele-overlay{position:fixed;inset:0;z-index:199;display:none}
.tele-overlay.open{display:block}

/* ─── MISC ────────────────────────────────────── */
.ext-link{color:var(--green);cursor:pointer;text-decoration:underline}
.ext-link:hover{color:var(--teal)}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:var(--mantle)}
::-webkit-scrollbar-thumb{background:var(--surface1);border-radius:2px}

/* ─── PROJECT GRID ────────────────────────────────────────────────────────── */
.project-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin:8px 0;
}
.project-grid .video-slot{max-height:180px}

/* ─── PROJECT VIDEO ───────────────────────────────────────────────────────── */
.video-slot{cursor:default}
.proj-video{
  width:100%;height:100%;object-fit:cover;
  display:block;transition:opacity .3s;
}

/* ─── PUSH TAGS TO BOTTOM OF CARD ────────────────────────────────────────── */
.project-card{display:flex;flex-direction:column}
.proj-meta{display:flex;flex-direction:column;flex:1}
.proj-desc{flex:1}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   These are fallback rules — main.js applies layout changes via inline style
   first, which always wins. These handle font/spacing/component tweaks.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── TABLET + MOBILE (<1024px) ─────────────────────────────────────────── */
@media(max-width:1024px){
  .filetree{display:none!important;width:0!important;min-width:0!important;border:none!important}
  .layout{display:block!important;width:100%!important}
  .editor{display:block!important;width:100%!important}
  .code-view{display:flex;width:100%}
  .tab{padding:0 14px;font-size:11px}
  .tab-close{display:none}
  .telescope{width:min(560px,calc(100vw - 32px))}
  .project-grid{grid-template-columns:1fr 1fr;gap:14px}
}

/* ─── MOBILE (<640px) ───────────────────────────────────────────────────── */
@media(max-width:639px){
  html,body{font-size:13px}
  .code-view{font-size:13px}
  .code-content{padding:12px 0 12px 12px;line-height:1.85}
  .line-nums{min-width:32px;font-size:11px;padding:12px 4px 12px 0}
  .line-num{padding:0 5px}
  .tabline{height:34px}
  .tab{padding:0 10px;font-size:10px;gap:4px}
  .nvim-logo{padding:0 8px;font-size:9px}
  .c-heading{font-size:15px}
  .langs{gap:6px}
  .lang-pill{padding:3px 10px;font-size:11px}
  .diagnostic{font-size:11px}
  .project-grid{grid-template-columns:1fr!important;gap:12px}
  .project-grid .video-slot{max-height:200px}
  .proj-meta{padding:12px 14px}
  .proj-name{font-size:14px}
  .proj-desc{font-size:12px}
  .ptag{font-size:10px;padding:2px 8px}
  .c-input{width:100%!important;display:block;margin-top:4px}
  .c-textarea{font-size:12px}
  .statusline{height:20px;font-size:10px}
  .sl-mode{min-width:56px;padding:0 8px;font-size:10px}
  .sl-branch{padding:0 8px;font-size:10px}
  .sl-file{padding:0 8px;font-size:10px}
  .sl-filetype{padding:0 8px;font-size:10px}
  .sl-pos{padding:0 8px;min-width:40px;font-size:10px}
  .telescope{width:calc(100vw - 20px)}
  .code-content [style*="margin:0 0 8px 16px"]{margin-left:0!important}
}