:root{
  --bg: radial-gradient(circle at top left, #141629, #050510 55%);
  --card-bg: rgba(16,16,32,0.86);
  --card-border: rgba(255,255,255,0.12);
  --card-soft-bg: rgba(255,255,255,0.02);
  --accent: #7c5cff;
  --accent-soft: rgba(124,92,255,0.22);
  --accent2: #00e0ff;
  --accent-danger: #ff5c7c;
  --text: #f5f4ff;
  --text-soft: rgba(245,244,255,0.72);
  --text-mono: rgba(180,186,255,0.82);
  --radius-lg: 22px;
  --radius-md: 14px;
  --radius-pill: 999px;
  --blur-lg: 26px;
  --blur-md: 18px;
}

/* Reset */
*,
*::before,
*::after{
  box-sizing: border-box;
}
html, body{
  margin: 0;
  padding: 0;
}
body{
  min-height: 100vh;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", sans-serif;
  color: var(--text);
  background: var(--bg);
  background-attachment: fixed;
  position: relative;
  overflow-x: hidden;
}
img{ max-width: 100%; display: block; }
button, input, textarea, select{
  font: inherit;
}
button{
  border: none;
  background: none;
}

/* Noise & blob */
.noise{
  position: fixed;
  inset: -50px;
  pointer-events: none;
  opacity: 0.10;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1600 900' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='2.1' numOctaves='2' stitchTiles='noStitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
  z-index: -1;
}
.cursor-blob{
  position: fixed;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 10% 0%, rgba(0,224,255,0.75), transparent 55%),
    radial-gradient(circle at 90% 100%, rgba(124,92,255,0.85), transparent 55%);
  filter: blur(40px);
  opacity: 0.35;
  pointer-events: none;
  transform: translate(-50%, -50%);
  z-index: -2;
}

/* Layout */
.container{
  width: min(1120px, 100% - 32px);
  margin: 0 auto;
}
.section{
  padding: 72px 0;
}
.section__head{
  max-width: 640px;
  margin-bottom: 32px;
}
.section__title{
  font-size: clamp(1.7rem, 3vw, 2.1rem);
  margin: 0 0 10px;
}
.section__desc{
  margin: 0;
  color: var(--text-soft);
}

/* Glass */
.glass{
  background: linear-gradient(135deg, rgba(16,16,40,0.90), rgba(16,16,30,0.82));
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow:
    0 18px 45px rgba(0,0,0,0.68),
    0 0 0 1px rgba(255,255,255,0.04);
  position: relative;
  overflow: hidden;
}
.glass-soft{
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid rgba(255,255,255,0.08);
}

/* Header */
.header{
  position: sticky;
  top: 0;
  z-index: 20;
  backdrop-filter: blur(20px);
  background: linear-gradient(to bottom, rgba(5,5,18,0.86), transparent);
}
.header__inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0 10px;
}
.logo{
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
  position: relative;
}
.logo__blob{
  position: absolute;
  inset: -10px;
  border-radius: 999px;
  background: radial-gradient(circle at 0 0, rgba(0,224,255,0.45), transparent 55%);
  opacity: 0.45;
  filter: blur(10px);
  z-index: -1;
}
.logo__inner{
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: linear-gradient(135deg, rgba(16,16,40,0.95), rgba(16,16,30,0.90));
}
.logo__initials{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 0.9rem;
  color: #ffffff;
  background:
    radial-gradient(circle at 0 0, rgba(0,224,255,0.9), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(124,92,255,0.95), transparent 55%);
}
.logo__text{
  display: flex;
  flex-direction: column;
}
.logo__name{
  font-size: 0.9rem;
}
.logo__role{
  font-size: 0.70rem;
  color: var(--text-mono);
}

/* Nav */
.nav{
  display: flex;
  align-items: center;
  gap: 22px;
}
.nav a{
  color: var(--text-soft);
  text-decoration: none;
  font-size: 0.92rem;
}
.nav a:hover{
  color: var(--text);
}
.nav__cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(124,92,255,0.18), rgba(0,224,255,0.10));
  border: 1px solid rgba(124,92,255,0.42);
  box-shadow: 0 0 22px rgba(124,92,255,0.4);
}
.nav__cta i{
  font-size: 0.78rem;
}
.nav-toggle{
  display: none;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(10,10,26,0.92);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
}
.nav-toggle span{
  width: 14px;
  height: 2px;
  border-radius: 999px;
  background: rgba(255,255,255,0.85);
}

/* Hero */
.hero{
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(0, 1.05fr);
  gap: 32px;
  padding: 40px 0 32px;
  align-items: center;
}
.hero__content{
  max-width: 520px;
}
.hero__eyebrow{
  font-size: 0.82rem;
  color: var(--text-mono);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(9,9,24,0.9);
}
.mono{
  font-family: "SF Mono", ui-monospace, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}
.dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  display: inline-block;
}
.dot--green{
  background: radial-gradient(circle at 30% 0, #4ade80, #16a34a);
}
.dot--purple{
  background: radial-gradient(circle at 30% 0, #a855f7, #7c3aed);
}
.hero__title{
  font-size: clamp(2.3rem, 4vw, 3rem);
  line-height: 1.02;
  margin: 16px 0 10px;
}
.hero__subtitle{
  margin: 0 0 18px;
  color: var(--text-soft);
  font-size: 0.98rem;
}
.hero__actions{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}
.hero__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.hero__chip{
  font-size: 0.80rem;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
}

/* Buttons */
.btn{
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  cursor: pointer;
  overflow: hidden;
  text-decoration: none;
  color: var(--text);
}
.btn--primary{
  background: linear-gradient(135deg, #7c5cff, #00e0ff);
  box-shadow:
    0 0 24px rgba(124,92,255,0.55),
    0 0 50px rgba(0,224,255,0.42);
  border-color: rgba(255,255,255,0.45);
}
.btn--ghost{
  background: rgba(5,5,20,0.92);
}
.btn__shine{
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.22) 45%, transparent 80%);
  opacity: 0;
  transform: translateX(-40%);
}

/* Magnetic */
.magnetic{
  will-change: transform;
}

/* Hero card */
.hero__visual{
  position: relative;
}
.hero-card{
  padding: 16px;
}
.hero-card__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.pill{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
}
.pill--green{
  background: rgba(16,185,129,0.12);
  color: #bbf7d0;
  border: 1px solid rgba(74,222,128,0.4);
}
.pill--soft{
  background: rgba(37,99,235,0.10);
  color: rgba(191,219,254,0.96);
  border: 1px solid rgba(129,140,248,0.50);
}
.hero-card__body{
  display: grid;
  gap: 12px;
}
.hero-stats{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.stat{
  padding: 10px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.14);
  background: radial-gradient(circle at 0 0, rgba(124,92,255,0.20), transparent 55%);
}
.stat__label{
  font-size: 0.80rem;
  color: var(--text-soft);
  margin: 0 0 2px;
}
.stat__value{
  margin: 0 0 2px;
  font-size: 1.3rem;
  font-weight: 600;
}
.stat__hint{
  margin: 0;
  font-size: 0.78rem;
  color: var(--text-mono);
}
.hero-card__grid{
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
  gap: 10px;
}
.hero-widget{
  padding: 10px 12px;
}
.hero-widget__label{
  font-size: 0.78rem;
  color: var(--text-soft);
  margin: 0 0 2px;
}
.hero-widget__value{
  margin: 0 0 2px;
  font-weight: 600;
}
.hero-widget__hint{
  margin: 0;
  font-size: 0.78rem;
  color: var(--text-mono);
}
.hero-widget--kpi{
  background: radial-gradient(circle at 0 0, rgba(34,197,94,0.14), transparent 60%);
}
.hero-widget--activity{
  background: radial-gradient(circle at 100% 0, rgba(59,130,246,0.18), transparent 60%);
}
.hero-widget--pill{
  grid-column: span 2;
  display: flex;
  align-items: center;
  gap: 8px;
}
.badge{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 0.78rem;
}
.badge--green{
  background: rgba(16,185,129,0.12);
  color: #bbf7d0;
}
.hero-card__footer{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
}
.hero-avatars{
  display: flex;
}
.avatar{
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 2px solid rgba(15,23,42,1);
  background-size: cover;
  background-position: center;
  margin-right: -8px;
}
.avatar--1{ background-image: linear-gradient(135deg, #7c5cff, #00e0ff); }
.avatar--2{ background-image: linear-gradient(135deg, #ec4899, #f97316); }
.avatar--3{ background-image: linear-gradient(135deg, #22c55e, #06b6d4); }
.hero-card__note{
  margin: 0;
  font-size: 0.82rem;
  color: var(--text-soft);
}
.hero-orb{
  position: absolute;
  border-radius: 50%;
  filter: blur(32px);
  opacity: 0.7;
}
.hero-orb--1{
  width: 160px; height: 160px; left: -40px; top: -20px;
  background: radial-gradient(circle at 0 0, rgba(0,224,255,0.85), transparent 60%);
}
.hero-orb--2{
  width: 200px; height: 200px; right: -60px; bottom: -40px;
  background: radial-gradient(circle at 100% 100%, rgba(124,92,255,0.90), transparent 60%);
}

/* Glitch */
.glitch{
  position: relative;
}
.glitch__layer{
  position: absolute;
  inset: 0;
  mix-blend-mode: screen;
  opacity: 0;
  pointer-events: none;
}
.glitch__layer--1{ color: #7c5cff; }
.glitch__layer--2{ color: #00e0ff; }

/* Stats section */
.stats{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.stat-card{
  padding: 14px 14px 12px;
}
.stat-card__kpi{
  margin: 0 0 4px;
  font-size: 1.6rem;
  font-weight: 600;
}
.stat-card__label{
  margin: 0 0 6px;
  font-size: 0.95rem;
}
.stat-card__desc{
  margin: 0;
  font-size: 0.86rem;
  color: var(--text-soft);
}

/* Projects */
.projects2__bar{
  padding: 12px;
  border-radius: 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}
.projects2__filters{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.filter{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.76);
  cursor: pointer;
  font-size: 0.95rem;
}
.filter:hover{
  color: rgba(255,255,255,0.96);
}
.filter.is-active{
  border-color: rgba(124,92,255,0.35);
  background: linear-gradient(135deg, rgba(124,92,255,0.18), rgba(0,224,255,0.08));
  box-shadow: 0 0 26px rgba(124,92,255,0.14);
  color: rgba(255,255,255,0.95);
}

/* Tabs projets (1 bouton = 1 projet) */
.projects2__tabs{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.project-tab{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.76);
  cursor: pointer;
  font-size: 0.95rem;
}

.project-tab:hover{
  color: rgba(255,255,255,0.96);
}

.project-tab.is-active{
  border-color: rgba(124,92,255,0.35);
  background: linear-gradient(135deg, rgba(124,92,255,0.18), rgba(0,224,255,0.08));
  box-shadow: 0 0 26px rgba(124,92,255,0.14);
  color: rgba(255,255,255,0.95);
}

.projects2__cta{
  white-space: nowrap;
}
.link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.90rem;
  text-decoration: none;
  color: var(--accent2);
}
.link i{
  font-size: 0.80rem;
}

.featuredCases{
  display: grid;
  gap: 16px;
  margin-bottom: 18px;
}
.project2{
  position: relative;
  padding: 14px 14px 12px;
  border-radius: 18px;
  background: rgba(9,9,26,0.98);
  border: 1px solid rgba(255,255,255,0.12);
  overflow: hidden;
}
.project2::before{
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: conic-gradient(from 180deg at 50% 50%, rgba(124,92,255,0.28), rgba(0,224,255,0.20), rgba(251,191,36,0.18), rgba(124,92,255,0.28));
  opacity: 0.0;
  transition: opacity .2s ease;
  pointer-events: none;
}
.project2:hover::before{ opacity: 1; }

.project2.is-hidden{ display: none; }

.project2--featured{
  grid-column: span 3;
  display: none;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 14px;
  align-items: stretch;
  padding: 16px;
  cursor: default;
}
.project2--featured.is-active{
  display: grid;
}

.project2__media{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.10);
  background: radial-gradient(circle at 0 0, rgba(124,92,255,0.35), transparent 60%);
  position: relative;
  overflow: hidden;
  min-height: 220px;
}
.shot{
  position: absolute;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(15,23,42,0.98), rgba(15,23,42,0.92));
  box-shadow: 0 18px 35px rgba(0,0,0,0.65);
}
.project2__media--dash .shot--grid{
  inset: 22px 18px 40px 18px;
}
.project2__media--dash .shot--card{
  width: 160px; height: 86px; bottom: 22px; left: 22px;
  background: linear-gradient(135deg, rgba(15,23,42,1), rgba(12,10,32,1));
}
.project2__media--dash .shot--spark{
  width: 70px; height: 70px; top: 18px; right: 18px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 0%, rgba(0,224,255,0.95), rgba(124,92,255,0.92));
}

.project2__media--landing .shot--grid{
  inset: 26px 20px 46px 20px;
}
.project2__media--landing .shot--panel{
  width: 210px; height: 90px; bottom: 28px; left: 26px;
}
.project2__media--landing .shot--flare{
  width: 120px; height: 120px; right: -30px; top: -20px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 0, rgba(244,63,94,0.90), transparent 60%);
}

.project2__media--crm .shot--grid{
  inset: 26px 18px 54px 18px;
}
.project2__media--crm .shot--panel{
  width: 210px; height: 86px; top: 26px; left: 22px;
}
.project2__media--crm .shot--sidebar{
  width: 80px; top: 26px; bottom: 60px; left: 22px;
}
.project2__media--crm .shot--kpi{
  width: 120px; height: 70px; bottom: 28px; left: 22px;
}
.project2__media--crm .shot--kpi2{
  width: 120px; height: 70px; bottom: 28px; left: 156px;
}
.project2__media--crm .shot--kanban{
  width: 140px; height: 130px; bottom: 28px; right: 26px;
}

.project2__media--ecom .shot--grid{
  inset: 26px 18px 46px 18px;
}
.project2__media--ecom .shot--product{
  width: 170px; height: 110px; top: 30px; left: 26px;
}
.project2__media--ecom .shot--chart{
  width: 130px; height: 80px; bottom: 28px; right: 26px;
}
.project2__media--ecom .shot--spark{
  width: 110px; height: 110px; right: -26px; top: 8px;
  border-radius: 999px;
  background: radial-gradient(circle at 0 0, rgba(124,92,255,0.95), transparent 60%);
}

.project2__content{
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.project2__eyebrow{
  font-size: 0.82rem;
  color: var(--text-mono);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.project2__title{
  margin: 0;
  font-size: 1.1rem;
}
.project2__subtitle{
  margin: 0;
  font-size: 0.90rem;
  color: var(--text-soft);
}
.project2__tags{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.chip{
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 0.78rem;
  border: 1px solid rgba(255,255,255,0.14);
}
.chip--soft{
  background: rgba(15,23,42,0.92);
  color: rgba(226,232,240,0.95);
}
.chip--accent{
  border-color: rgba(124,92,255,0.45);
  background: rgba(124,92,255,0.10);
  color: #e0e7ff;
}
.project2__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 10px 0 0;
}
.project2__item dt{
  font-size: 0.80rem;
  color: var(--text-mono);
}
.project2__item dd{
  margin: 2px 0 0;
  font-size: 0.86rem;
  color: var(--text-soft);
}
.project2__bullets{
  padding-left: 18px;
  margin: 0;
}
.project2__bullets li{
  font-size: 0.86rem;
  color: var(--text-soft);
}
.project2__footer{
  margin-top: auto;
}

.projects2{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.project2__top{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.pill--outline{
  border-radius: 999px;
  padding: 4px 9px;
  border: 1px solid rgba(148,163,184,0.65);
  font-size: 0.76rem;
  color: rgba(148,163,184,1);
}

/* Timeline */
.timeline{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
}
.timeline__item{
  position: relative;
  padding: 14px 14px 12px 18px;
}
.timeline__badge{
  position: absolute;
  left: 10px;
  top: 12px;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: radial-gradient(circle at 0 0, rgba(124,92,255,0.95), rgba(0,224,255,0.95));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  font-weight: 600;
  box-shadow: 0 0 18px rgba(124,92,255,0.65);
}
.timeline__content{
  margin-left: 32px;
}
.timeline__title{
  margin: 0 0 4px;
  font-size: 1rem;
}
.timeline__desc{
  margin: 0 0 6px;
  color: var(--text-soft);
  font-size: 0.90rem;
}
.timeline__list{
  margin: 0;
  padding-left: 18px;
  font-size: 0.86rem;
  color: var(--text-soft);
}

/* Contact */
.contact-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.95fr);
  gap: 16px;
}
.contact-card{
  padding: 16px;
}
.contact-card__title{
  margin: 0 0 6px;
  font-size: 1.2rem;
}
.contact-card__desc{
  margin: 0 0 14px;
  color: var(--text-soft);
  font-size: 0.9rem;
}
.contact-form{
  display: grid;
  gap: 10px;
}
.field{
  display: grid;
  gap: 4px;
}
.field label{
  font-size: 0.84rem;
  color: var(--text-mono);
}
input, textarea, select{
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(8,8,22,0.95);
  padding: 8px 10px;
  color: var(--text);
}
textarea{
  resize: vertical;
}
.field--inline{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.contact-side{
  padding: 16px;
}
.contact-side__title{
  margin: 0 0 8px;
}
.contact-list{
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
  display: grid;
  gap: 8px;
}
.contact-list__label{
  font-size: 0.80rem;
  color: var(--text-mono);
}
.contact-list__value{
  font-size: 0.92rem;
}
.contact-list a{
  color: var(--accent2);
  text-decoration: none;
}
.contact-side__cta{
  margin-bottom: 10px;
}
.contact-side__text{
  margin: 0 0 8px;
  font-size: 0.90rem;
  color: var(--text-soft);
}
.contact-side__note{
  font-size: 0.86rem;
  color: var(--text-soft);
}

/* Footer */
.footer{
  padding: 28px 0 40px;
  font-size: 0.82rem;
  color: rgba(148,163,184,0.92);
}

/* Utilities */
.badge i,
.chip i,
.pill i{
  font-size: 0.80rem;
}

/* Responsive */
@media (max-width: 900px){
  .hero{
    grid-template-columns: minmax(0, 1fr);
  }
  .hero__visual{
    order: -1;
  }
  .hero-card__grid{
    grid-template-columns: minmax(0, 1fr);
  }
  .hero-widget--pill{
    grid-column: auto;
  }
  .stats{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .projects2{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .project2--featured{
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    grid-column: auto;
  }
  .contact-grid{
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 720px){
  .header__inner{
    padding-inline: 0;
  }
  .nav-toggle{
    display: flex;
  }
  .nav{
    position: fixed;
    inset: 52px 16px auto 16px;
    border-radius: 18px;
    padding: 10px 12px;
    background: rgba(5,5,18,0.98);
    border: 1px solid rgba(255,255,255,0.14);
    display: none;
    flex-direction: column;
    gap: 10px;
  }
  .nav.is-open{
    display: flex;
  }
  .hero{
    padding-top: 24px;
  }
  .projects2__bar{
    flex-direction: column;
    align-items: flex-start;
  }
  .project2--featured{
    grid-template-columns: minmax(0, 1fr);
  }
  .projects2{
    grid-template-columns: minmax(0, 1fr);
  }
  .stats{
    grid-template-columns: minmax(0, 1fr);
  }
  .field--inline{
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 520px){
  .hero-card{
    padding: 12px;
  }
  .project2__grid{
    grid-template-columns: 1fr;
  }
  .project2--featured{
    grid-column: auto;
    grid-template-columns: 1fr;
  }
}
@media (max-width: 520px){
  .stats{ grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .cursor-blob{ display: none; }
}

/* ---- Font Awesome polish ---- */
i.fa-solid, i.fa-regular, i.fa-brands{
  line-height: 1;
  display: inline-block;
}
