/* =========================
   THEME / TOKENS
========================= */
:root{
  --bg: #070A13;
  --bg2: #050812;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.09);
  --stroke: rgba(255,255,255,.14);

  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.70);
   
  --nav-active: #38BDF8;
   
  --accent: #4EE1FF;
  --accent2: #A78BFA;

  --shadow: 0 22px 70px rgba(0,0,0,.42);
  --shadow2: 0 12px 34px rgba(0,0,0,.24);

  --radius: 18px;
  --radius2: 24px;

  --container: 1120px;
  --headerH: 74px;

  --font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* =========================
   BASE / RESET
========================= */
*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font);
  color: var(--text);
  background: radial-gradient(1200px 700px at 20% 0%, rgba(78,225,255,.08), transparent 55%),
              radial-gradient(1200px 700px at 85% 20%, rgba(167,139,250,.08), transparent 55%),
              linear-gradient(180deg, var(--bg), var(--bg2));
  overflow-x:hidden;
}

a{ color: inherit; text-decoration: none; }
strong{ font-weight: 750; }

.mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

.container{
  width: min(92vw, var(--container));
  margin: 0 auto;
}

.section{
  padding: 88px 0;
}

.section__head{
  margin-bottom: 24px;
}
.section__head h2{
  margin:0;
  font-size: clamp(22px, 3vw, 32px);
  letter-spacing: -0.03em;
}
.muted{ color: var(--muted); }
.small{ font-size: 13px; }
.tiny{ font-size: 12px; }

.accent{
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Better list spacing inside cards */
.card ul { padding-left: 1.1rem; }
.card li { margin-bottom: 0.45rem; }

/* =========================
   ACCESSIBILITY / FOCUS
========================= */
:focus{ outline: none; }
:focus-visible{
  outline: 2px solid rgba(78,225,255,.55);
  outline-offset: 3px;
  border-radius: 10px;
}

/* Motion preferences */
@media (prefers-reduced-motion: reduce){
  *{
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
}

/* =========================
   BACKGROUND TECH VIBES
========================= */
.bg{ position: fixed; inset:0; z-index:-2; pointer-events:none; }

.grid{
  position:absolute; inset:-60px;
  background:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 70px 70px;
  transform: perspective(900px) rotateX(58deg) translateY(-180px);
  opacity: .32;
  filter: blur(.2px);
}

.glow{
  position:absolute; width: 560px; height: 560px; border-radius: 50%;
  filter: blur(70px);
  opacity: .32;
}
.glow-a{ left: -160px; top: 8vh; background: radial-gradient(circle, var(--accent), transparent 60%); }
.glow-b{ right: -190px; bottom: 6vh; background: radial-gradient(circle, var(--accent2), transparent 60%); }

/* =========================
   HEADER / NAV
========================= */
.header{
  position: sticky; top: 0; z-index: 50;
  height: var(--headerH);
  backdrop-filter: blur(16px);
  background: rgba(7,10,19,.66);
  border-bottom: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 12px 40px rgba(0,0,0,.22);
}

.header__inner{
  height: var(--headerH);
  display:flex; align-items:center; justify-content: space-between;
  gap: 16px;
}

.brand{
  display:flex; align-items:center; gap:10px;
  font-weight: 850;
  letter-spacing: -0.03em;
}

.brand__dot{
  width: 10px; height: 10px; border-radius: 50%;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow: 0 0 0 6px rgba(78,225,255,.12);
}

.nav{ display:flex; gap: 18px; align-items:center; }

.nav a{
  color: rgba(255,255,255,.78);
  font-weight: 650;
  font-size: 14px;
  padding: 10px 10px;
  border-radius: 12px;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
  border: 1px solid transparent;
}
.nav a:hover{
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.95);
  border-color: rgba(255,255,255,.10);
}
.nav a.active{
  background: rgba(56,189,248,.14);   
  color: #38BDF8;                    
  border: 1px solid rgba(56,189,248,.40);
}


.nav__toggle{
  display:none;
  width: 44px; height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  cursor:pointer;
  transition: transform .15s ease, background .15s ease;
}
.nav__toggle:hover{ transform: translateY(-1px); background: rgba(255,255,255,.085); }
.nav__toggle span{
  display:block;
  width: 18px; height: 2px;
  background: rgba(255,255,255,.85);
  margin: 4px auto;
  border-radius: 99px;
}

/* =========================
   HERO
========================= */
.hero{ padding-top: 96px; }

.hero__inner{
  display:grid;
  grid-template-columns: 1.25fr .85fr;
  gap: 24px;
  align-items: start;
}

.badge{
  display:inline-flex; align-items:center; gap:10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  padding: 10px 12px;
  border-radius: 999px;
  font-size: 13px;
  color: rgba(255,255,255,.80);
}

.badge__ping{
  width:10px; height:10px; border-radius:50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(78,225,255,.5);
  animation: ping 1.6s infinite;
}

@keyframes ping{
  0%{ box-shadow:0 0 0 0 rgba(78,225,255,.5); }
  70%{ box-shadow:0 0 0 10px rgba(78,225,255,0); }
  100%{ box-shadow:0 0 0 0 rgba(78,225,255,0); }
}

.hero__title{
  margin: 14px 0 10px;
  font-size: clamp(32px, 4.4vw, 56px);
  line-height: 1.04;
  letter-spacing: -0.045em;
}

.hero__subtitle{
  margin: 0 0 16px;
  color: rgba(255,255,255,.78);
  font-size: 16px;
  line-height: 1.7;
  max-width: 62ch;
}

.hero__cta{
  display:flex; gap: 12px; flex-wrap: wrap;
  margin-top: 10px;
}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  font-weight: 750;
  font-size: 14px;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease;
  box-shadow: 0 10px 24px rgba(0,0,0,.16);
}
.btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.22);
}
.btn:active{ transform: translateY(0); }

.btn--primary{
  background: linear-gradient(90deg, rgba(78,225,255,.18), rgba(167,139,250,.18));
  border-color: rgba(255,255,255,.22);
}
.btn--ghost{
  background: rgba(255,255,255,.04);
}

.btn__icon{ display:inline-flex; align-items:center; }

.quick-links{
  display:flex; flex-wrap: wrap; gap: 10px;
  margin-top: 18px;
}

.chip{
  display:inline-flex; align-items:center; gap:10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.86);
  font-weight: 750;
  font-size: 13px;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.chip:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-1px);
}
.chip__icon{
  width: 34px;
  height: 34px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.chip__icon img{
  width: 25px !important;
  height: 25px !important;
  object-fit: contain;
  display: block;
}

/* Right hero card */
.hero__card{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  box-shadow: var(--shadow);
  padding: 18px;
  position: sticky;
  top: calc(var(--headerH) + 16px);
}

.stat{ padding: 12px 0; }
.stat__label{
  font-size: 12px;
  color: rgba(255,255,255,.62);
  text-transform: uppercase;
  letter-spacing: .12em;
}
.stat__value{
  margin-top: 6px;
  font-weight: 850;
  color: rgba(255,255,255,.94);
}

.divider{
  height:1px;
  background: rgba(255,255,255,.12);
  margin: 12px 0;
}

/* =========================
   GRIDS / CARDS
========================= */
.grid-2{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}
.grid-3{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 16px;
}

.card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  box-shadow: var(--shadow2);
  padding: 16px 16px;
}

.card h3{
  margin: 0 0 8px;
  letter-spacing: -0.02em;
  font-size: 16px;
}
.card p{
  margin: 0;
  line-height: 1.65;
  color: rgba(255,255,255,.74);
}

.card--hover{
  transition: transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.card--hover:hover{
  transform: translateY(-3px);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.24);
  box-shadow: 0 16px 46px rgba(0,0,0,.28);
}

/* bullets */
.bullets{
  margin: 0;
  padding-left: 18px;
  color: rgba(255,255,255,.74);
}
.bullets li{
  margin: 10px 0;
  line-height: 1.6;
}

/* =========================
   TIMELINE
========================= */
.timeline{
  display:flex;
  flex-direction: column;
  gap: 14px;
}
.t-item{
  display:grid;
  grid-template-columns: 22px 1fr;
  gap: 12px;
  align-items: start;
}
.t-dot{
  width: 12px; height: 12px;
  border-radius: 50%;
  margin-top: 18px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  box-shadow: 0 0 0 6px rgba(78,225,255,.10);
}
.t-card{ padding: 14px 14px; }

/* =========================
   CONTACT
========================= */
.actions{
  display:flex; gap: 10px; flex-wrap: wrap;
  margin-top: 10px;
}

.contact-list{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
}

.contact-item{
  display:flex; align-items:center; gap: 12px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.contact-item:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-1px);
}

.icon{
  width: 40px; height: 40px;
  border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(90deg, rgba(78,225,255,.10), rgba(167,139,250,.10));
}

/* =========================
   FOOTER
========================= */
.footer{
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.70);
}

/* =========================
   TO TOP
========================= */
.to-top{
  position: fixed;
  right: 22px;
  bottom: 22px;
  width: 56px;
  height: 56px;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
  font-weight: 900;
  cursor: pointer;
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease, background .18s ease;
}
.to-top.show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.to-top:hover{ background: rgba(255,255,255,.12); }

/* =========================
   MODAL
========================= */
.modal{ position: fixed; inset:0; z-index: 80; display:none; }
.modal.show{ display:block; }

.modal__overlay{
  position:absolute; inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(8px);
}

.modal__panel{
  position: relative;
  width: min(92vw, 560px);
  margin: 10vh auto;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(7,10,19,.86);
  box-shadow: var(--shadow);
  padding: 16px;
}

.modal__head{
  display:flex; align-items:center; justify-content: space-between;
  gap: 12px;
}
.modal__head h3{
  margin:0;
  font-size: 16px;
  letter-spacing: -0.02em;
}

.icon-btn{
  width: 40px; height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.9);
  cursor:pointer;
  transition: background .15s ease, transform .15s ease, border-color .15s ease;
}
.icon-btn:hover{
  background: rgba(255,255,255,.09);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-1px);
}

.modal__actions{ display:flex; gap: 10px; flex-wrap: wrap; margin: 12px 0; }
.modal__small{ display:grid; gap: 10px; margin-top: 10px; }

.field{
  display:grid; gap: 6px;
  font-size: 13px;
  color: rgba(255,255,255,.78);
}

input, textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  outline: none;
  transition: border-color .15s ease, background .15s ease;
}
input:hover, textarea:hover{ background: rgba(255,255,255,.08); }
input:focus-visible, textarea:focus-visible{ border-color: rgba(78,225,255,.45); }
textarea{ resize: vertical; min-height: 110px; }

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 980px){
  .hero__inner{ grid-template-columns: 1fr; }
  .hero__card{ position: relative; top: 0; }
  .grid-3{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 720px){
  .nav{ display:none; }
  .nav.open{
    display:flex;
    position:absolute;
    left: 4vw;
    right: 4vw;
    top: calc(var(--headerH) + 10px);
    flex-direction: column;
    padding: 12px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(7,10,19,.92);
    box-shadow: 0 18px 60px rgba(0,0,0,.35);
  }
  .nav__toggle{ display:block; }
  .grid-2{ grid-template-columns: 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .hero{ padding-top: 84px; }
}
/* ===== Projects UI ===== */

#projects .filters{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin: 1rem 0 1.25rem;
}

.filters{
  display:flex; flex-wrap:wrap; gap:.5rem;
  margin: 1rem 0 1.25rem;
}
.chip{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: inherit;
  padding: .5rem .75rem;
  border-radius: 999px;
  cursor:pointer;
  transition: transform .15s ease, background .2s ease, border-color .2s ease;
}
.chip:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.28); }
.chip.active{
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.35);
}

.projects-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1rem;
}
.project-card{
  grid-column: span 6;
  border-radius: 18px;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;
  position:relative;
  transform: translateY(10px);
  opacity: 0;
  transition: transform .25s ease, opacity .25s ease, border-color .25s ease;
}
.project-card.reveal{ transform: translateY(0); opacity:1; }
.project-card:hover{
  transform: translateY(-4px);
  border-color: rgba(255,255,255,.28);
}

/* subtle animated glow */
.project-card::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(600px circle at var(--mx, 20%) var(--my, 20%), rgba(255,255,255,.16), transparent 40%);
  opacity:.0;
  transition: opacity .25s ease;
  pointer-events:none;
}
.project-card:hover::before{ opacity:1; }

.project-top{
  padding: 1.1rem 1.1rem .8rem;
  display:flex; flex-direction:column; gap:.6rem;
}
.project-title{
  display:flex; justify-content:space-between; align-items:flex-start; gap:1rem;
}
.project-title h3{ margin:0; font-size:1.05rem; letter-spacing:.2px; }
.badge{
  font-size:.78rem;
  padding:.25rem .55rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
  white-space:nowrap;
}
.project-desc{ margin:0; opacity:.85; line-height:1.45; }

.tags{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:.25rem; }
.tag{
  font-size:.78rem;
  padding:.25rem .5rem;
  border-radius:999px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  opacity:.95;
}

.project-actions{
  display:flex; gap:.5rem; flex-wrap:wrap;
  padding: 0 1.1rem 1.1rem;
}
.pbtn{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.55rem .75rem;
  border-radius: 12px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color:inherit;
  text-decoration:none;
  cursor:pointer;
  transition: transform .15s ease, background .2s ease, border-color .2s ease;
}
.pbtn:hover{ transform: translateY(-1px); border-color: rgba(255,255,255,.28); }
.pbtn.primary{ background: rgba(255,255,255,.12); }
.pbtn.ghost{ background: transparent; }

/* Responsive */
@media (max-width: 900px){
  .project-card{ grid-column: span 12; }
}

/* ===== Modal ===== */
.modal{ position:fixed; inset:0; display:none; z-index: 1000; }
.modal.open{ display:block; }
.modal-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}
.modal-card{
  position:relative;
  width:min(860px, calc(100% - 2rem));
  margin: 6vh auto;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(20,20,25,.92);
  box-shadow: 0 20px 70px rgba(0,0,0,.45);
  padding: 1.1rem 1.1rem 1.25rem;
  animation: pop .18s ease-out;
}
@keyframes pop{ from{ transform: translateY(8px); opacity:.0; } to{ transform: translateY(0); opacity:1; } }

.modal-close{
  position:absolute; top:.85rem; right:.85rem;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color:inherit;
  border-radius: 12px;
  padding:.35rem .55rem;
  cursor:pointer;
}
.modal h3{ margin: .2rem 0 .6rem; }
.modal ul{ margin:.4rem 0 0 1.1rem; opacity:.9; }
/* Smooth entrance for filters */
#projects .filters{
  animation: fadeUp .35s ease both;
}

@keyframes fadeUp{
  from{ opacity: 0; transform: translateY(8px); }
  to{ opacity: 1; transform: translateY(0); }
}

/* Better alignment: force grid to respect container nicely */



/* =========================
   PROJECTS — BUTTONS + FILTERS (override)
   Put at the VERY END of the CSS file
========================= */

/* Only inside Projects: fix typography + size consistency */
#projects .filters .chip,
#projects .pbtn{
  font-family: var(--font);
  font-weight: 750;
  font-size: 13px;
  letter-spacing: -0.01em;
}

/* Filters look (only in Projects) */
#projects .filters .chip{
  padding: 10px 12px;               
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  transition: background .15s ease, border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
#projects .filters .chip:hover{
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-1px);
}

#projects .filters .chip.active{
  background: linear-gradient(90deg, rgba(78,225,255,.18), rgba(167,139,250,.18));
  border-color: rgba(255,255,255,.28);
  box-shadow: 0 0 0 4px rgba(78,225,255,.10);
}

#projects .filters .chip.active::before{
  content:"";
  width:8px; height:8px;
  border-radius:999px;
  display:inline-block;
  margin-right:.45rem;
  background: var(--accent);
  box-shadow: 0 0 10px rgba(78,225,255,.45);
}

#projects .pbtn{
  padding: 10px 12px;
  border-radius: 14px;
  font-weight: 750;
}
#projects .pbtn.primary{
  background: linear-gradient(90deg, rgba(78,225,255,.18), rgba(167,139,250,.18));
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 10px 24px rgba(0,0,0,.16);
}
#projects .pbtn.ghost{
  background: rgba(255,255,255,.04);
}

#projects .projects-grid{
  width: 100%;
}
/* Project poster thumbnail – preview style */
#projects .project-thumb{
  width: calc(100% - 2.2rem);
  height: 220px;                
  margin: 1.1rem 1.1rem 0;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  position: relative;
}

#projects .project-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;            
  object-position: top center;  
  transition: transform .5s ease;
}

/* Hover subtle */
#projects .project-card:hover .project-thumb img{
  transform: scale(1.05);
}

#projects .project-thumb::after{
  content: "View full poster in details";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 12px;
  font-size: 12px;
  color: rgba(255,255,255,.85);
  background: linear-gradient(to top, rgba(0,0,0,.45), transparent 60%);
  opacity: 0;
  transition: opacity .3s ease;
}

#projects .project-card:hover .project-thumb::after{
  opacity: 1;
}
/* Full poster inside Details modal */
/* Modal: make content scrollable */
#projectModal, #projectModal * { font-family: var(--font); }
#projectModal .modal-card{
  max-height: 86vh;         
  overflow: auto;          
}

#projectModal .modal-poster{
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  margin-bottom: 1rem;
}

#projectModal .modal-poster img{
  width: 100%;
  height: auto;
  display: block;
  background: #f6f4ee;
}
/* Contact list icons only */
.contact-list .icon{
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 40px;                
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}

.contact-list .icon img{
  width: 22px !important;
  height: 22px !important;
  object-fit: contain;
  display: block;
}
/* ===== AI Typing Intro ===== */
#aiIntro{
  min-height: 56px;           
}

.typing{
  position: relative;
  display: inline;
  padding-right: 6px;
}

/* caret */
.typing::after{
  content: "";
  display: inline-block;
  width: 10px;
  height: 1.1em;
  margin-left: 6px;
  transform: translateY(3px);
  background: rgba(255,255,255,.75);
  animation: blink .9s infinite;
  border-radius: 2px;
}

@keyframes blink{
  0%, 45% { opacity: 1; }
  55%, 100% { opacity: 0; }
}
/* Animated grid overlay */
.hero{
  position: relative;
  overflow: hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:-60px;                
  pointer-events:none;
  opacity: .14;

  background:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,.12) 0px,
      rgba(255,255,255,.12) 1px,
      transparent 1px,
      transparent 48px
    ),
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,.10) 0px,
      rgba(255,255,255,.10) 1px,
      transparent 1px,
      transparent 48px
    );

  transform: translate3d(0,0,0);
  animation: gridDrift 14s linear infinite;
}

@keyframes gridDrift{
  0%   { background-position: 0px 0px, 0px 0px; }
  100% { background-position: 160px 120px, 160px 120px; }
}

@media (prefers-reduced-motion: reduce){
  .hero::before{ animation: none; }
}
