/* styles.css
   Terminal Noir — refined + animated
   Replace your existing styles.css with this file.
   - Monospace-first terminal aesthetic
   - Subtle animated accents: glows, flicker, entrance, floating
   - Pure-CSS (no JS changes required)
   - Keeps selectors: body.theme-cyber, .wrap, .site-header, .terminal, .btn, .gallery, etc.
*/

:root{
  --bg-1:#020304;
  --bg-2:#041018;
  --panel:#06121a;
  --text:#cfeef1;
  --muted:#7f9aa2;
  --accent:#00ff82;
  --accent-2:#5af0ff;
  --glass: rgba(255,255,255,0.03);
  --radius:12px;
  --container:1180px;
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, monospace;
  --ui:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  --shadow-lg: 0 22px 64px rgba(2,6,12,0.75);
  --transition: 240ms cubic-bezier(.2,.9,.3,1);
}

/* Base */
html,body{height:100%}
body.theme-cyber{
  margin:0;
  min-height:100%;
  color:var(--text);
  background:
    radial-gradient(700px 240px at 8% 12%, rgba(0,255,130,0.02), transparent 8%),
    linear-gradient(180deg,var(--bg-1), var(--bg-2));
  font-family:var(--ui);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.46;
}

/* Layout helpers */
.wrap{max-width:var(--container);margin:0 auto;padding:1.25rem}
.header-inner, .footer-grid{display:flex;align-items:center;justify-content:space-between;gap:12px}

/* Header */
.site-header{
  position:sticky; top:0; z-index:60;
  padding:.6rem 0;
  background:linear-gradient(180deg, rgba(2,6,10,0.78), rgba(2,6,10,0.28));
  border-bottom:1px solid rgba(255,255,255,0.02);
  backdrop-filter: blur(6px);
  transform:translateZ(0); /* GPU layer for smoother blur */
}
.brand{
  display:inline-block;
  font-family:var(--mono);
  font-weight:800;
  color:var(--accent);
  letter-spacing:1px;
  text-decoration:none;
  padding:8px 12px;
  border-radius:10px;
  background:linear-gradient(90deg, rgba(0,255,130,0.03), rgba(90,240,255,0.02));
  box-shadow:0 8px 28px rgba(0,0,0,0.6);
  transition:transform var(--transition);
}
.brand:hover{transform:translateY(-2px)}

/* Nav */
.nav{display:flex;gap:12px}
.nav a{color:var(--muted);text-decoration:none;padding:8px;border-radius:8px;font-weight:600}
.nav a:hover{color:var(--text);background:rgba(255,255,255,0.02)}

/* HERO: split layout */
.hero{display:grid;grid-template-columns:1fr 440px;gap:2rem;align-items:center;padding:3.2rem 0;position:relative;overflow:visible}
.hero-left{z-index:20}
.hero-left h1{
  font-family:var(--mono);font-weight:800;font-size:clamp(2.0rem,4.2vw,3.2rem);margin:0 0 .6rem 0;color:var(--text);
  letter-spacing:0.6px;
  will-change:filter,transform;
}
.hero-left h1 .accent{color:var(--accent)}
.lead{color:var(--muted);margin:0 0 1.1rem 0;font-size:1.03rem;max-width:56ch}

/* Animated accent underline for headings */
.hero-left h1::after{
  content:"";
  display:block;
  width:48%;
  height:6px;
  margin-top:10px;
  border-radius:8px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  opacity:.18;
  transform-origin:left center;
  animation: slowPulse 3.8s ease-in-out infinite;
}
@keyframes slowPulse{
  0%{opacity:.12;transform:scaleX(.98)}
  50%{opacity:.26;transform:scaleX(1.02)}
  100%{opacity:.12;transform:scaleX(.98)}
}

/* CTA buttons */
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;padding:10px 14px;border-radius:10px;text-decoration:none;font-weight:800;border:1px solid rgba(255,255,255,0.03);cursor:pointer;
  transition:transform var(--transition), box-shadow var(--transition), filter var(--transition);
  will-change:transform,box-shadow;
}
.btn-primary{
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  color:#021216;border:none;box-shadow:0 14px 36px rgba(0,0,0,0.6);
}
.btn-ghost{background:transparent;color:var(--accent);border:1px solid rgba(0,255,130,0.08)}
.btn:active{transform:translateY(1px) scale(.998)}
.btn-primary:hover{transform:translateY(-5px) rotate(-0.2deg);box-shadow:0 20px 46px rgba(0,0,0,0.7)}
.btn-ghost:hover{transform:translateY(-4px);filter:brightness(1.06)}

/* subtle focus ring for keyboard users */
.btn:focus{outline:3px solid rgba(0,255,130,0.12);outline-offset:3px;box-shadow:0 20px 50px rgba(0,0,0,0.5)}

/* Terminal / image card with gentle floating */
.terminal{
  background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(0,0,0,0.06));
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.03);
  overflow:hidden;box-shadow:var(--shadow-lg);
  transform-origin:center;
  animation: floatSlow 8s ease-in-out infinite;
}
@keyframes floatSlow{
  0%{transform:translateY(0) rotate(0.0001deg)}
  45%{transform:translateY(-6px) rotate(-0.15deg)}
  100%{transform:translateY(0) rotate(0.0001deg)}
}

/* Terminal header (window chrome) */
.term-head{display:flex;gap:8px;padding:10px;background:linear-gradient(180deg, rgba(0,0,0,0.18), rgba(0,0,0,0.06));align-items:center}
.dot{width:12px;height:12px;border-radius:50%}
.dot.red{background:#ff6b6b}
.dot.yellow{background:#ffd66b}
.dot.green{background:var(--accent)}
.term-head .label{flex:1;color:var(--muted);font-family:var(--mono);font-size:.88rem}

/* Terminal body & image */
.term-body{position:relative;background:#051220}
.hero-media{width:100%;height:320px;object-fit:cover;display:block;filter:contrast(1.02) saturate(1.06);transition:transform 600ms var(--transition),filter 600ms var(--transition)}
.terminal:hover .hero-media{transform:scale(1.02) translateY(-2px);filter:brightness(.9) saturate(1.12)}

/* subtle scanline flicker overlay (animated) */
.term-body::after{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,0.01) 1px, transparent 1px);
  background-size:100% 3px;
  opacity:.06;pointer-events:none;
  animation: scanline 2.8s linear infinite;
}
@keyframes scanline{
  0%{transform:translateY(0);opacity:.06}
  50%{transform:translateY(2px);opacity:.04}
  100%{transform:translateY(0);opacity:.06}
}

/* slight terminal text flicker (applies to captions using .flicker) */
.flicker{
  display:inline-block;animation: flickerFrame 3.6s steps(6,end) infinite;
}
@keyframes flickerFrame{
  0%{opacity:1;filter:brightness(1)}
  2%{opacity:.6;filter:brightness(.9)}
  8%{opacity:1;filter:brightness(1)}
  10%{opacity:.85;filter:brightness(.95)}
  100%{opacity:1;filter:brightness(1)}
}

/* Services grid */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:2rem}
.service{background:var(--panel);padding:1.1rem;border-radius:10px;border:1px solid rgba(255,255,255,0.02);transition:transform 320ms var(--transition),box-shadow var(--transition)}
.service:hover{transform:translateY(-8px);box-shadow:0 30px 80px rgba(0,0,0,0.6)}
.service h3{font-family:var(--mono);font-weight:700;margin:0 0 .5rem 0;color:var(--accent)}
.service p{color:var(--muted);margin:0;font-size:.98rem}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:1.75rem}
.gallery .item{position:relative;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,0.03);background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(0,0,0,0.04))}
.gallery img{width:100%;height:180px;object-fit:cover;display:block;filter:brightness(.68) saturate(1.05);transition:transform 520ms var(--transition),filter 520ms var(--transition)}
.gallery .item:hover img{transform:scale(1.04);filter:brightness(.82) saturate(1.08)}
.caption{position:absolute;left:12px;bottom:12px;background:linear-gradient(90deg, rgba(0,0,0,0.6), rgba(0,0,0,0.25));padding:6px 8px;border-radius:8px;color:var(--text);font-family:var(--mono);font-weight:700;font-size:.95rem;backdrop-filter:blur(2px)}

/* Contact strip */
.contact-strip{margin-top:2rem;padding:12px;border-radius:10px;background:linear-gradient(90deg, rgba(0,255,130,0.02), rgba(90,240,255,0.02));display:flex;justify-content:space-between;align-items:center;border:1px solid rgba(255,255,255,0.02)}
.contact-strip .left{color:var(--text)}
.contact-strip .right{color:var(--muted);text-align:right}

/* Footer */
.site-footer{padding:1.25rem 0;border-top:1px solid rgba(255,255,255,0.02);margin-top:3.5rem;color:var(--muted)}

/* Code-rain canvas (kept low opacity) */
#code-rain{position:fixed;left:0;top:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.06;mix-blend-mode:screen}

/* Utility: subtle entrance animation for cards */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
.service, .gallery .item, .terminal{animation:fadeUp 560ms cubic-bezier(.2,.9,.3,1) both}

/* Responsiveness */
@media (max-width:1000px){
  .hero{grid-template-columns:1fr;gap:1rem;padding:2rem 0}
  .services{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .nav{display:none}
}
@media (max-width:640px){
  .services{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .hero-media{height:220px}
}

/* Accessibility: reduce motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
  .hero-left h1::after{display:none}
  .terminal{animation:none}
}
