/* ============================================================================
   HOGU Development — base palette & type
   You normally don't need to touch this file; edit site-data.js for content.
   To change the accent color, edit `accent` in site-data.js (it overrides --accent).
   ============================================================================ */
:root{
  --bg:#0a0d0a;
  --panel:#0e120f;
  --panel2:#0b0f0c;
  --shell:#0c100c;
  --border:#1b231a;
  --border-soft:#141a13;
  --txt:#e6ede4;
  --txt-bright:#f2f6f0;
  --txt2:#8c978a;
  --txt3:#5c6659;
  --code:#cdd6cb;
  --amber:#d6a23a;
  --red:#ff5555;
  --accent:#6ee84f;
  --accent-soft:rgba(110,232,79,0.12);
  --accent-line:rgba(110,232,79,0.30);
  --accent-glow:rgba(110,232,79,0.45);
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:'Helvetica Neue',Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--sans);-webkit-font-smoothing:antialiased;}
::selection{background:var(--accent);color:#0a0d0a;}
a{color:inherit;}
img,svg{display:block;}

@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}
@keyframes draw{from{stroke-dashoffset:2000}to{stroke-dashoffset:0}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px;}
.mono{font-family:var(--mono);}
.g{color:var(--accent);}
.sm{font-size:13px;}
.dim{color:var(--txt3);}
.dim2{color:var(--txt2);}
.right{text-align:right;}
section{scroll-margin-top:84px;}

/* shared dot */
.dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);display:inline-block;}
.pulse{animation:pulse 2s infinite;}
.cursor{display:inline-block;width:.5em;height:.92em;background:var(--accent);margin-left:7px;transform:translateY(3px);animation:blink 1s steps(1) infinite;}
.cursor.sm{width:8px;height:14px;margin-left:5px;transform:translateY(2px);}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(10,13,10,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);}
.nav__inner{height:68px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.brand{font-family:var(--mono);font-weight:700;font-size:18px;letter-spacing:.3px;text-decoration:none;white-space:nowrap;color:var(--amber);}
.nav__links{display:flex;align-items:center;gap:26px;font-family:var(--mono);font-size:14px;}
.nav__links a{color:var(--amber);text-decoration:none;padding-bottom:3px;border-bottom:2px solid transparent;transition:.15s;}
.nav__links a:hover{color:#e8b84a;border-bottom-color:var(--amber);}
.nav__icon{color:var(--amber);display:inline-flex;border-bottom:none!important;}
.nav__icon:hover{color:#e8b84a;}

/* HERO */
.hero{padding:60px 24px 36px;display:flex;gap:48px;flex-wrap:wrap;align-items:flex-start;}
.hero__left{flex:1 1 420px;min-width:300px;}
.hero__right{flex:1 1 480px;min-width:320px;display:flex;flex-direction:column;gap:16px;}
.kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:2px;color:var(--accent);}
.hero__title{font-size:clamp(40px,5.6vw,66px);line-height:1.05;font-weight:700;letter-spacing:-1.6px;margin:18px 0 0;white-space:pre-line;color:var(--amber);}
.hero__tagline{font-family:var(--mono);font-size:clamp(15px,1.8vw,19px);font-weight:500;letter-spacing:-.2px;color:var(--accent);margin:14px 0 0;}
.hero__lede{font-size:17px;line-height:1.6;color:var(--txt2);max-width:440px;margin:16px 0 0;}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px;}
.btn{display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-family:var(--mono);font-size:14px;padding:13px 20px;border-radius:9px;cursor:pointer;transition:.15s;border:none;}
.btn--primary{background:var(--accent);color:#0a1108;font-weight:700;}
.btn--primary:hover{filter:brightness(1.1);box-shadow:0 0 22px var(--accent-glow);}
.btn--ghost{background:transparent;color:var(--accent);font-weight:600;border:1px solid var(--accent-line);}
.btn--ghost:hover{background:var(--accent-soft);border-color:var(--accent);}
.frame{position:relative;margin-top:30px;padding:16px 18px;max-width:420px;}
.frame__c{position:absolute;width:12px;height:12px;}
.frame__c.tl{top:0;left:0;border-top:1px solid var(--accent-line);border-left:1px solid var(--accent-line);}
.frame__c.tr{top:0;right:0;border-top:1px solid var(--accent-line);border-right:1px solid var(--accent-line);}
.frame__c.bl{bottom:0;left:0;border-bottom:1px solid var(--accent-line);border-left:1px solid var(--accent-line);}
.frame__c.br{bottom:0;right:0;border-bottom:1px solid var(--accent-line);border-right:1px solid var(--accent-line);}
.frame__txt{font-family:var(--mono);font-size:13px;color:var(--accent);}

/* EDITOR */
.editor{background:var(--panel2);border:1px solid var(--border);border-radius:11px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);}
.editor__bar{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--panel);}
.tl-dot{width:11px;height:11px;border-radius:50%;}
.tl-dot.r{background:#ff5f56;}.tl-dot.y{background:#ffbd2e;}.tl-dot.g{background:#27c93f;}
.editor__body{display:flex;min-height:236px;font-family:var(--mono);}
.explorer{width:150px;flex:none;border-right:1px solid var(--border);padding:13px 12px;font-size:12px;color:var(--txt2);}
.explorer div{padding:3px 0;}
.explorer__h{color:var(--txt3);letter-spacing:1.5px;font-size:10.5px;margin-bottom:10px;}
.explorer__file{padding:4px 8px!important;}
.explorer__file.active{margin-top:10px;background:var(--accent-soft);border-radius:5px;color:var(--accent);}
.code{flex:1;padding:13px 16px;font-size:12.5px;line-height:1.75;position:relative;overflow:hidden;color:#d4d4d4;white-space:normal;}
.code .ln{display:block;white-space:pre;}
.code .g0{display:inline-block;width:22px;color:#858585;user-select:none;}
/* VS Code Dark+ syntax tokens */
.code .st{color:#569cd6;}   /* storage type: def */
.code .kw{color:#c586c0;}   /* control keywords: if, return */
.code .fn{color:#dcdcaa;}   /* function names & calls */
.code .str{color:#ce9178;}  /* strings */
.code .var{color:#9cdcfe;}  /* variables, params, dunder */
.code .num{color:#b5cea8;}  /* numbers */
.badge{position:absolute;top:11px;right:13px;display:inline-flex;align-items:center;gap:6px;font-size:10.5px;color:var(--accent);border:1px solid var(--accent-line);border-radius:20px;padding:3px 10px;}
.badge .dot{width:6px;height:6px;}

/* STATUS / ACTIVITY */
.panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px 16px;}
.panel__h{font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;color:var(--accent);margin-bottom:12px;}
.panel__h2{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:1.5px;color:var(--accent);}
.panel .row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;padding:3px 0;color:var(--code);}
.spark{width:100%;height:56px;}
.panel .sm{font-family:var(--mono);font-size:10px;color:var(--txt3);}

/* PROJECTS */
.card-shell{border:1px solid var(--border);border-radius:16px;background:var(--shell);padding:26px;}
.section-kicker{font-family:var(--mono);font-size:13px;letter-spacing:2px;color:var(--accent);margin-bottom:20px;}
#projects,#about{padding:28px 0;}
.tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px;}
.tab{padding:7px 14px;border-radius:7px;font-family:var(--mono);font-size:13px;cursor:pointer;white-space:nowrap;background:transparent;color:var(--txt2);border:1px solid var(--border);font-weight:500;transition:.15s;}
.tab:hover{filter:brightness(1.12);}
.tab.active{background:var(--accent);color:#0a1108;border-color:var(--accent);font-weight:700;}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px;}
.pcard{background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:.18s;}
.pcard:hover{border-color:var(--accent-line);transform:translateY(-3px);}
.pcard__bar{display:flex;align-items:center;gap:9px;padding:11px 14px;border-bottom:1px solid var(--border);}
.pcard__bar .dot{width:8px;height:8px;box-shadow:0 0 6px var(--accent-glow);}
.pcard__file{font-family:var(--mono);font-size:12.5px;color:var(--txt2);}
.pcard__preview{padding:14px;min-height:152px;border-bottom:1px solid var(--border-soft);background:var(--panel2);}
.pcard__body{padding:16px;display:flex;flex-direction:column;gap:10px;flex:1;}
.pcard__body h3{margin:0;font-size:19px;font-weight:700;color:var(--amber);}
.pcard__body p{margin:0;font-size:13.5px;line-height:1.5;color:var(--txt2);}
.tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:2px;}
.tag{font-family:var(--mono);font-size:11px;color:var(--accent);border:1px solid var(--accent-line);border-radius:5px;padding:2px 9px;}
.plinks{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:13px;border-top:1px solid var(--border-soft);font-family:var(--mono);font-size:13px;}
.plinks a{display:inline-flex;align-items:center;gap:7px;color:var(--txt2);text-decoration:none;transition:.15s;}
.plinks a:hover{color:var(--accent);}
.plinks .sep{color:#28321f;}
/* preview variants */
.pv-chart .t{font-family:var(--mono);font-size:12px;color:var(--txt2);}
.pv-chart .v{font-family:var(--mono);font-size:16px;color:var(--txt);margin:4px 0 8px;}
.pv-chart svg{width:100%;height:72px;}
.pv-chart .x{display:flex;justify-content:space-between;margin-top:4px;font-family:var(--mono);font-size:10.5px;color:var(--txt3);}
.pv-check .h{font-family:var(--mono);font-size:12px;color:var(--txt2);margin-bottom:8px;}
.pv-check .it{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-family:var(--mono);font-size:13px;}
.pv-check .l{display:flex;align-items:center;gap:9px;color:var(--code);}
.pv-check .box{width:15px;height:15px;border-radius:4px;border:1px solid var(--accent-line);display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:var(--accent);}
.pv-term{font-family:var(--mono);font-size:12px;line-height:1.55;white-space:pre;}
.pv-img{height:124px;border-radius:8px;background:repeating-linear-gradient(45deg,#10160f,#10160f 8px,#0c110b 8px,#0c110b 16px);display:flex;align-items:center;justify-content:center;border:1px dashed #25301f;}
.pv-img span{font-family:var(--mono);font-size:12px;color:var(--txt3);}
.coming{border:1px dashed #25301f;border-radius:12px;padding:72px 24px;text-align:center;}
.coming__cmd{font-family:var(--mono);font-size:13px;color:var(--txt3);margin-bottom:14px;}
.coming__title{font-size:clamp(26px,4vw,38px);font-weight:700;letter-spacing:-1px;color:var(--amber);}
.coming__sub{font-family:var(--mono);font-size:13.5px;color:var(--txt2);margin:12px 0 0;}
.more{text-align:center;margin-top:26px;}
.more a{font-family:var(--mono);font-size:14px;color:var(--accent);text-decoration:none;}
.more a:hover{text-decoration:underline;}

/* SERVICES */
.section-title{font-size:clamp(26px,3.4vw,36px);font-weight:700;letter-spacing:-1px;margin:0 0 26px;color:var(--amber);}
.services{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;}
.svc{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:20px;transition:.18s;}
.svc:hover{border-color:var(--accent-line);transform:translateY(-3px);}
.svc__cmd{font-family:var(--mono);font-size:12px;color:var(--accent);margin-bottom:14px;}
.svc h3{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--amber);}
.svc p{margin:0;font-size:13.5px;line-height:1.55;color:var(--txt2);}
#services{padding:40px 0 28px;}

/* ABOUT */
.about{display:flex;gap:48px;flex-wrap:wrap;margin-top:14px;}
.about__left{flex:1 1 380px;min-width:280px;}
.about__right{flex:1 1 300px;min-width:260px;}
.about__name{font-family:var(--mono);font-size:24px;color:var(--amber);font-weight:700;}
.about__role{font-family:var(--mono);font-size:13px;color:var(--accent);margin:5px 0 18px;}
.about__bio{color:var(--txt2);line-height:1.65;font-size:15px;max-width:480px;margin:0;}
.about__sign{font-family:var(--mono);font-size:14px;color:var(--accent);margin-top:20px;}
.fact{display:flex;align-items:center;gap:13px;padding:11px 0;border-bottom:1px solid var(--border-soft);font-family:var(--mono);font-size:14px;color:var(--accent);}
.fact .sq{width:8px;height:8px;background:var(--accent);border-radius:2px;flex:none;box-shadow:0 0 6px var(--accent-glow);}

/* CONTACT */
#contact{padding:40px 0;}
.contact{display:flex;gap:48px;flex-wrap:wrap;align-items:flex-start;}
.contact__left{flex:1 1 320px;min-width:280px;}
.contact__lede{color:var(--txt2);line-height:1.6;font-size:15px;max-width:380px;margin:8px 0 24px;}
.contact__left .section-title{margin:8px 0 16px;}
.contact__right{flex:1 1 380px;min-width:300px;}
.form{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:16px;}
.form label{display:flex;flex-direction:column;gap:7px;font-family:var(--mono);font-size:12px;color:var(--txt2);}
.form input,.form textarea{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:11px 13px;color:var(--txt);font-family:var(--mono);font-size:14px;resize:vertical;}
.form input:focus,.form textarea:focus{border-color:var(--accent);outline:none;}
.form .btn{align-self:flex-start;}

/* FOOTER */
.footer{border-top:1px solid var(--border);margin-top:56px;}
.footer .wrap{padding-top:28px;padding-bottom:28px;}
.footer__links{display:flex;flex-wrap:wrap;gap:24px;align-items:center;}
.footer__links a{display:inline-flex;align-items:center;gap:8px;color:var(--txt2);text-decoration:none;font-family:var(--mono);font-size:13px;transition:.15s;}
.footer__links a:hover{color:var(--accent);}
.footer__legal{margin-top:20px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;font-family:var(--mono);font-size:12.5px;color:var(--txt3);}
