:root{
  --bg:#0a0f0a;           /* deep black/green */
  --text:#e6ffe6;         /* mint white */
  --muted:#9fe6a0;        /* soft neon green */
  --brand:#00ff88;        /* neon green */
  --brand-2:#00e6b8;      /* cyan-green */
  --card:#0d140f;         /* dark card */
  --border:#11331c;       /* greenish border */
}
:root[data-theme="dark"]{
  --bg:#050a05;
  --text:#eaffea;
  --muted:#8ddf90;
  --brand:#00ff88;
  --brand-2:#00e6b8;
  --card:#0a110c;
  --border:#0f2a19;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:var(--bg);color:var(--text)}
a{color:var(--brand);text-decoration:none}
.container{width:min(1100px,92%);margin:0 auto}
.nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-bottom:1px solid var(--border);--gutter: clamp(12px,4vw,32px);padding-block:14px;padding-left: max(var(--gutter), env(safe-area-inset-left));padding-right: max(var(--gutter), env(safe-area-inset-right))}
.brand{display:flex;gap:10px;align-items:center;font-weight:800;color:var(--text)}
.brand .logo{width:36px;height:36px;border-radius:6px;box-shadow:0 0 0 2px var(--border), 0 8px 24px rgba(0,255,136,.15)}
.brand-text{letter-spacing:.2px}
.menu{display:flex;gap:18px}
.actions{display:flex;gap:10px;align-items:center}
.btn{padding:8px 12px;border:1px dashed var(--brand);border-radius:8px;background:transparent;color:var(--text);transition:transform .15s, box-shadow .15s}
.btn:hover{transform:translateY(-1px);box-shadow:0 0 0 2px var(--brand) inset,0 8px 24px rgba(0,255,136,.15)}
.btn.primary{background:transparent;border:1px solid var(--brand);color:var(--text);text-shadow:0 0 6px rgba(0,255,136,.6)}
.icon-btn{border:1px solid var(--border);background:var(--card);border-radius:8px;padding:8px 10px;cursor:pointer;box-shadow:0 0 0 1px var(--border)}
.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:20px;align-items:flex-start;padding:20px 0}
.hero h1{font-size:clamp(28px,6vw,48px);line-height:1.05;margin:0;text-shadow:0 0 10px rgba(0,255,136,.35)}
.hero p{color:var(--muted);font-size:18px}
.glow{position:relative}
.glow:before{content:"";position:absolute;inset:-20px;background:radial-gradient(600px 200px at 10% 10%,rgba(0,255,136,.18),transparent),radial-gradient(600px 200px at 90% 30%,rgba(0,230,184,.12),transparent);filter:blur(20px);z-index:-1}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;margin:26px 0}
.card{background:linear-gradient(180deg,rgba(0,255,136,.04),transparent),var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;transition:.25s;min-height:unset;box-shadow:0 0 0 1px var(--border) inset}
.card:hover{transform:translateY(-3px);box-shadow:0 0 0 1px var(--brand) inset,0 10px 30px rgba(0,255,136,.12)}
/* Compact chips in hero */
.hero .cards{display:flex;flex-direction:column;gap:10px;margin:0}
@media (min-width: 900px){.hero .cards{justify-self:end;max-width:420px}}
.hero .card{display:inline-block;padding:8px 12px;border-radius:10px;min-height:auto;font-size:14px;font-weight:600;background:rgba(0,255,136,.06);border:1px solid rgba(0,255,136,.35);box-shadow:none}
.hero .card:hover{transform:none;box-shadow:0 0 0 1px var(--brand) inset}
.section{padding:30px 0}
.section h2{font-size:28px;margin:0 0 14px}
.projects{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.project{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 0 0 1px var(--border)}
.project .cover{aspect-ratio:16/9;width:100%;background:#0ea5e9}
.project .body{padding:12px}
.footer{padding:22px 0;border-top:1px solid var(--border);margin-top:30px}
.logo-banner{height:28px;opacity:.9}
.cookie-banner{position:fixed;left:50%;transform:translateX(-50%);bottom:16px;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;display:flex;gap:12px;align-items:center;padding:10px 12px;box-shadow:0 8px 30px rgba(0,255,136,.1)}
.cookie-banner.hidden{display:none}
.cookie-actions{display:flex;gap:8px}
.cookie-text{font-size:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form input,.form textarea, .form select{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text)}
.form label{font-weight:600;font-size:14px}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid var(--border);padding:10px;text-align:left}
.badge{display:inline-block;padding:4px 8px;border-radius:999px;border:1px solid var(--border);font-size:12px}
.alert{padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--card)}

/* Accessibility and focus states */
.btn:focus-visible, .icon-btn:focus-visible, a:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:2px solid var(--brand);
  outline-offset:2px;
}

/* Mobile navigation */
.menu-toggle{display:none}
@media (max-width: 768px){
  .nav{justify-content:flex-start;gap:8px;--gutter: clamp(12px,5vw,24px);padding-block:10px;padding-left: max(var(--gutter), env(safe-area-inset-left));padding-right: max(var(--gutter), env(safe-area-inset-right))}
  .brand{margin-right:0}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--brand);background:var(--card);border-radius:8px;padding:8px 10px;margin-left:auto;color:var(--brand)}
  .menu{position:absolute;top:56px;left:0;right:0;background:var(--bg);border-bottom:1px solid var(--border);display:none;flex-direction:column;gap:10px;padding:10px var(--gutter)}
  .menu.open{display:flex}
  .actions{gap:8px;margin-left:8px}
  .hero{grid-template-columns:1fr;padding:16px 0}
  .grid-2{grid-template-columns:1fr}
}

/* Larger screens tweaks */
@media (min-width: 1200px){
  .container{width:min(1200px,88%)}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{animation:none!important;transition:none!important}
}

/* Terminal subtle scanlines & grid (optional flair) */
body{
  background-image:
    radial-gradient(1000px 400px at 10% -10%, rgba(0,255,136,.06), transparent),
    radial-gradient(800px 300px at 110% 10%, rgba(0,230,184,.05), transparent),
    repeating-linear-gradient(0deg, rgba(0,0,0,.0), rgba(0,0,0,.0) 2px, rgba(0,255,136,.02) 3px, rgba(0,0,0,.0) 4px);
}

/* Typing effect base */
.type-target{opacity:0;white-space:pre-wrap;display:inline-block}
.type-caret::after{content:"\2588"; /* block cursor */ display:inline-block;margin-left:2px;color:var(--brand);animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
@media (prefers-reduced-motion: reduce){
  .type-caret::after{animation:none}
}

/* Prompt style (adds ">" or "$" look) */
.prompt::before{content:">$ "; color:var(--brand); opacity:.9; margin-right:6px}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(12px) scale(0.99);transition:opacity .5s ease, transform .5s ease}
.reveal.show{opacity:1;transform:none}
/* Fun runner mouse */
.runner-mouse{position:fixed;left:0;top:0;transform:translate(-50%,-50%);pointer-events:none;z-index:9999;font-size:22px;line-height:1;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
@media (max-width:768px){.runner-mouse{font-size:18px}}
@media (prefers-reduced-motion: reduce){.runner-mouse{display:none}}
/* Fun runner cat */
.runner-cat{position:fixed;left:0;top:0;transform:translate(-50%,-50%);pointer-events:none;z-index:9998;font-size:26px;line-height:1;filter:drop-shadow(0 3px 8px rgba(0,0,0,.5))}
@media (max-width:768px){.runner-cat{font-size:22px}}
@media (prefers-reduced-motion: reduce){.runner-cat{display:none}}
/* Speech bubbles */
.speech{position:fixed;left:0;top:0;transform:translate(-50%,-120%);pointer-events:none;z-index:9999;background:var(--card);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:6px 8px;font-size:12px;line-height:1.2;box-shadow:0 6px 16px rgba(0,0,0,.25);opacity:0;transition:opacity .2s ease}
.speech.show{opacity:1}
/* Rat house safe zone */
.rat-house{position:fixed;left:18px;bottom:18px;width:120px;height:80px;border:1px solid var(--border);border-radius:60px 60px 0 0;background:linear-gradient(180deg, rgba(0,255,136,.12), rgba(0,0,0,.6));box-shadow:inset 0 -20px 30px rgba(0,0,0,.5), 0 6px 20px rgba(0,0,0,.35);pointer-events:none;z-index:5}
.rat-house::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:56px;height:46px;background:#020;border-radius:56px 56px 0 0;border:1px solid rgba(0,255,136,.35)}

/* Toast */
.toast{position:fixed;left:50%;top:18px;transform:translateX(-50%);background:var(--card);color:var(--text);border:1px solid var(--brand);border-radius:10px;padding:10px 14px;z-index:10000;box-shadow:0 10px 30px rgba(0,0,0,.35)}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* ===== Services: Hacker Terminal Style ===== */
#services .projects{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
#services .project{background:transparent;border:1px dashed rgba(0,255,136,.5);border-radius:12px;box-shadow:0 0 0 1px rgba(0,255,136,.25) inset;position:relative;transition:box-shadow .2s, transform .15s}
#services .project:hover{transform:translateY(-2px);box-shadow:0 0 0 1px var(--brand) inset,0 0 18px rgba(0,255,136,.18)}
#services .project .cover{display:none}
#services .project .body{padding:12px 14px}
#services .project .body strong{display:block;font-size:16px;letter-spacing:.3px;text-shadow:0 0 6px rgba(0,255,136,.35)}
#services .project .body .muted{color:var(--muted)}
#services .project .body strong::before{content:">$ "; color:var(--brand); margin-right:6px}
#services .project::after{content:"";position:absolute;inset:0;border-radius:12px;background:repeating-linear-gradient(0deg, rgba(0,255,136,.06), rgba(0,255,136,.06) 1px, transparent 2px, transparent 4px);opacity:0;pointer-events:none;transition:opacity .2s}
#services .project:hover::after{opacity:.7}
@media (max-width:768px){
  #services .projects{grid-template-columns:1fr}
}

/* ===== Terminal Contact Form (Hacker style) ===== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.terminal-form{background:linear-gradient(180deg,rgba(0,255,136,.06),transparent),var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:0 0 0 1px var(--border) inset}
.terminal-form label{display:block;font-weight:800;margin:6px 0 6px;color:var(--text)}
.terminal-form input[type="text"],
.terminal-form input[type="email"],
.terminal-form select,
.terminal-form textarea{width:100%;background:transparent;color:var(--text);border:1px dashed var(--brand);border-radius:8px;padding:8px 10px;outline:none}
.terminal-form input::placeholder,
.terminal-form textarea::placeholder{color:var(--muted)}
.terminal-form input:focus,
.terminal-form select:focus,
.terminal-form textarea:focus{box-shadow:0 0 0 2px var(--brand) inset}
.terminal-form .hp{position:absolute;left:-9999px;opacity:0}
#contact-status.success{color:#22c55e}
#contact-status.error{color:#ef4444}
