/* =================================================================
   ÉRIC FOYE — Freelance Portfolio
   Brutalisme Éditorial — Cream, Black, Terracotta
   Serif/Sans mix: Playfair Display + Manrope
   Taste Skill dials: V8 / M6 / D3
   ================================================================= */

/* --- Tokens -------------------------------------------------------- */
:root {
  --cream:   #f5f4f0;
  --cream-d: #eae8e2;
  --ink:     #0a0a0a;
  --ink-70:  #454545;
  --ink-50:  #737373;
  --ink-30:  #a3a3a3;
  --ink-15:  #d4d4d4;
  --ink-08:  rgba(10,10,10,.08);
  --ink-05:  rgba(10,10,10,.05);
  --accent:  #c9503c;
  --accent-h:#b3402f;
  --accent-bg:rgba(201,80,60,.06);
  --accent-border:rgba(201,80,60,.25);

  --serif: 'Playfair Display', 'Georgia', serif;
  --sans:  'Manrope', system-ui, -apple-system, sans-serif;
  --mono:  'IBM Plex Mono', ui-monospace, monospace;

  --ease-out-expo: cubic-bezier(.16,1,.3,1);
  --ease-spring:   cubic-bezier(.34,1.56,.64,1);
  --dur-fast:   .2s;
  --dur-normal: .45s;
  --dur-slow:   .7s;

  --radius-sm:  8px;
  --radius-md:  16px;
  --radius-lg:  24px;
  --radius-xl:  32px;

  --max-w: 1320px;
  --gutter: clamp(1rem, 4vw, 2rem);
}

/* --- Reset --------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
::selection{background:var(--accent);color:#fff}

html{
  scroll-behavior:smooth;
  font-size:16px;
  -webkit-text-size-adjust:100%;
}

body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

/* noise overlay */
body::after{
  content:'';position:fixed;inset:0;
  pointer-events:none;z-index:9999;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:200px;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* --- Typography ---------------------------------------------------- */
h1,h2,h3{font-weight:700;line-height:1.08;letter-spacing:-.025em}

/* Serif display — editorial brutalist identity */
.display{
  font-family:var(--serif);
  font-size:clamp(2rem,4.2vw,3.2rem);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:700;
}
.display em{font-style:italic;font-weight:700}

.heading-2{
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(3rem, 6vw, 5.5rem) !important;
  font-weight: 500 !important;
  letter-spacing: -0.03em !important;
  text-transform: none !important;
}
.heading-3{
  font-family: var(--sans) !important;
  font-size: 1.5rem !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: -0.015em !important;
}

.body-lg{
  font-family: var(--sans) !important;
  font-size: 1.1rem !important;
  color: #4A4A4A !important;
  line-height: 1.65 !important;
  max-width: 58ch;
}
.body-sm{font-size:.85rem;line-height:1.5}
.mono{font-family:var(--mono);font-size:.78rem;letter-spacing:.02em}
.muted{color:var(--ink-50)}
.accent{color:var(--accent)}

.eyebrow{
  font-family:var(--mono);font-size:.68rem;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink-50);
}

/* --- Page Shell ---------------------------------------------------- */
.page{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}

/* --- Nav ----------------------------------------------------------- */
.nav{
  position:fixed;top:12px;left:50%;transform:translateX(-50%);
  z-index:200;
  width:calc(100% - var(--gutter)*2);max-width:var(--max-w);
  pointer-events:none;
  display:flex;justify-content:space-between;align-items:center;
}

.nav__logo{
  pointer-events:auto;
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px 8px 10px;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--ink-08);
  border-radius:var(--radius-md);
  box-shadow:0 6px 18px -6px rgba(15,15,15,.12);
  font-size:.88rem;font-weight:700;letter-spacing:-.02em;
  transition:all var(--dur-normal) var(--ease-out-expo);
}
.nav__logo:hover{border-color:rgba(10,10,10,.15);box-shadow:0 14px 30px -8px rgba(15,15,15,.2)}

.nav__logo-icon{
  width:28px;height:28px;background:var(--ink);
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.72rem;font-weight:800;
  transition:transform var(--dur-normal) var(--ease-spring);
}
.nav__logo:hover .nav__logo-icon{transform:scale(1.06) rotate(-6deg)}

.nav__pills{
  pointer-events:auto;
  display:flex;align-items:center;gap:4px;
  padding:6px 8px;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--ink-08);
  border-radius:999px;
  box-shadow:0 6px 18px -6px rgba(15,15,15,.12);
  transition:all var(--dur-normal) var(--ease-out-expo);
}

.nav__link{
  padding:8px 16px;font-size:.78rem;font-weight:600;
  color:var(--ink-50);border-radius:999px;
  transition:all var(--dur-fast) ease-out;position:relative;
}
.nav__link::before{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:var(--ink-05);transform:scaleX(0);transform-origin:left;
  transition:transform var(--dur-normal) var(--ease-out-expo);
}
.nav__link:hover{color:var(--ink)}
.nav__link:hover::before{transform:scaleX(1)}
.nav__link span{position:relative;z-index:1}

.nav__cta{
  padding:8px 18px;font-size:.78rem;font-weight:600;
  color:#fff;background:var(--ink);border-radius:999px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  transition:all var(--dur-normal) var(--ease-out-expo);
}
.nav__cta:hover{background:#1a1a1a;transform:translateY(-1px);box-shadow:0 14px 32px -10px rgba(0,0,0,.45)}
.nav__cta:active{transform:scale(.97)}

/* --- Hero (Split-screen) ------------------------------------------- */
.hero{
  min-height: calc(100vh - 280px);
  display:grid;grid-template-columns:1.15fr 1fr;
  gap:clamp(1rem,2vw,2rem);align-items:center;
  padding-top:4.5rem;padding-bottom:0.5rem;
}

.hero__copy{display:flex;flex-direction:column;gap:1rem;padding-right:1rem}

.hero__tag{
  display:inline-flex;align-items:center;gap:8px;width:fit-content;
  padding:6px 14px;
  border:1px solid var(--accent-border);background:var(--accent-bg);
  border-radius:999px;
  font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.04em;
  color:var(--accent);transition:all .3s ease-out;
}
.hero__tag:hover{border-color:rgba(201,80,60,.5);background:rgba(201,80,60,.1);transform:translateY(-1px)}

.hero__tag-dot{position:relative;width:6px;height:6px}
.hero__tag-dot::before{content:'';position:absolute;inset:0;border-radius:50%;background:var(--accent)}
.hero__tag-dot::after{
  content:'';position:absolute;inset:0;border-radius:50%;background:var(--accent);
  opacity:.6;animation:ping 1.5s cubic-bezier(0,0,.2,1) infinite;
}
@keyframes ping{75%,100%{transform:scale(2.5);opacity:0}}

.hero__sub{margin-top:.4rem;color:var(--ink-70);max-width:480px}

.hero__ctas{display:flex;gap:12px;margin-top:.6rem;flex-wrap:wrap}

/* Primary CTA */
.btn-primary{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;font-size:.88rem;font-weight:600;
  color:#fff;background:var(--ink);border:none;border-radius:var(--radius-lg);
  box-shadow:0 14px 32px -8px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.1);
  cursor:pointer;overflow:hidden;
  transition:all var(--dur-normal) var(--ease-out-expo);
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,transparent,rgba(255,255,255,.1),transparent);
  transform:translateX(-100%);transition:transform .7s ease-out;
}
.btn-primary:hover{box-shadow:0 24px 44px -10px rgba(201,80,60,.25),0 18px 40px -10px rgba(0,0,0,.5);transform:translateY(-1px)}
.btn-primary:hover::before{transform:translateX(100%)}
.btn-primary:active{transform:scale(.98)}

.btn-primary__arrow{transition:transform var(--dur-normal) var(--ease-spring)}
.btn-primary:hover .btn-primary__arrow{transform:translateX(4px)}

.btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;font-size:.88rem;font-weight:500;
  color:var(--ink);background:#fff;
  border:1px solid var(--ink-15);border-radius:var(--radius-lg);
  box-shadow:0 3px 10px -2px rgba(0,0,0,.05);cursor:pointer;
  transition:all .3s ease-out;
}
.btn-secondary:hover{border-color:var(--ink-30);background:var(--cream-d);box-shadow:0 10px 22px -6px rgba(0,0,0,.1)}
.btn-secondary:active{transform:scale(.98)}

/* Hero images */
.hero__images{
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1.2fr .8fr;
  gap:12px;height:min(380px,48vh);
}
.hero__img{
  border-radius:var(--radius-lg);overflow:hidden;position:relative;
  transition:transform var(--dur-normal) var(--ease-out-expo);
}
.hero__img:hover{transform:scale(1.015)}
.hero__img img{width:100%;height:100%;object-fit:cover}
.hero__img--tall{grid-row:1/-1}
.hero__img--accent{
  background:var(--accent);display:flex;align-items:flex-end;padding:1.2rem;
}
.hero__img--accent span{
  color:#fff;font-family:var(--mono);font-size:.68rem;
  text-transform:uppercase;letter-spacing:.12em;opacity:.7;
}

/* --- Section spacing ----------------------------------------------- */
.section{padding:clamp(4rem,8vw,7rem) 0}
.section + .section{border-top:1px solid var(--ink-05)}

/* --- Trusted By (logo wall) ---------------------------------------- */
.trusted{padding:2rem 0 1rem;border-bottom:none}
.trusted + .section{border-top:none}

@keyframes scrollMarquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.marquee-container {
  mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
  overflow: hidden;
  width: 100%;
}

.marquee-track {
  display: flex;
  white-space: nowrap;
  overflow: visible;
  animation: scrollMarquee 40s linear infinite;
  gap: 0;
  align-items: center;
  padding: 1rem 0;
}

.trusted__logo{
  height: 65px !important;
  width: auto !important;
  opacity:.35;
  filter:grayscale(1);
  transition:all var(--dur-normal) var(--ease-out-expo);
  flex-shrink: 0;
  margin: 0 60px !important;
}
.trusted__logo:hover{opacity:.7;filter:grayscale(0)}
.trusted__logo img{height:100%;width:auto;object-fit:contain}

/* Scaling for specific logos in the marquee */
.trusted-logo-google,
.trusted-logo-smartbox,
.trusted-logo-avaya,
.trusted-logo-perfetti,
.trusted-logo-disney,
.trusted-logo-citi {
  transform: scale(2.2) !important;
}

.trusted-logo-sncf {
  transform: scale(1.5) !important;
}

.trusted-logo-playstation {
  transform: scale(1.2) !important;
}

.trusted-logo-sfr {
  transform: scale(1.5) !important;
}

/* Mastered Platforms */
.platforms-section {
  width: 100vw;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  padding: 4rem var(--gutter) !important;
  background: var(--cream-d);
  border-top: 1px solid var(--ink-05);
  border-bottom: 1px solid var(--ink-05);
}

.platforms{
  text-align:center;
  max-width: var(--max-w);
  margin: 0 auto;
  width: 100%;
}
.platforms__heading{margin-bottom:1.5rem}

.platforms__grid{
  display:flex;align-items:center;justify-content:center;
  gap:2rem;flex-wrap:wrap;
  margin-bottom:1rem;
  overflow:visible;
}
.platform-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 18px;
  background:#fff;border:1px solid var(--ink-08);
  border-radius:var(--radius-md);
  font-size:.82rem;font-weight:500;
  box-shadow:0 2px 8px -2px rgba(0,0,0,.04);
  transition:all var(--dur-normal) var(--ease-out-expo);
}
.platform-item:hover{
  border-color:var(--ink-15);
  box-shadow:0 8px 20px -6px rgba(0,0,0,.1);
  transform:translateY(-2px);
}
.platform-item__icon{
  width:22px;height:22px;flex-shrink:0;
}
.platform-item__icon img{width:100%;height:100%;object-fit:contain}

.platform-logo-xurrent {
  width: auto !important;
  height: 40px !important;
  aspect-ratio: auto !important;
  border-radius: 0 !important;
}

.platform-logo-servicenow {
  width: auto !important;
  height: 20px !important;
  aspect-ratio: auto !important;
  border-radius: 0 !important;
}

.platform-item--servicenow {
  padding: 14px 24px !important;
}

.platform-logo-salesforce {
  transform: scale(1.5) !important;
  aspect-ratio: auto !important;
  border-radius: 0 !important;
}

.platform-item--salesforce {
  padding: 14px 24px !important;
  gap: 15px !important;
}

.zendesk-pill {
  padding: 12px 24px !important;
}

.zendesk-pill .platform-logo-zendesk {
  width: auto !important;
  height: 24px !important;
  max-height: 24px !important;
}

.zendesk-pill img {
  max-height: 24px !important;
  width: auto !important;
}

.platform-logo-ewoq {
  transform: scale(1.6) !important;
  margin-right: 16px !important;
  aspect-ratio: auto !important;
  border-radius: 0 !important;
}

.platform-item--salesforce span,
.platform-item--ewoq span,
.platform-item--zendesk span {
  font-size: 1.15rem !important;
  font-weight: 700 !important;
}

.platforms__note{
  margin-top:1.2rem;
  font-family:var(--mono);font-size:.72rem;
  color:var(--ink-50);font-style:italic;
}

/* --- Experience ---------------------------------------------------- */
#experience {
  width: 100vw;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  padding: 6rem var(--gutter) !important;
  background: transparent;
  border-top: 1px solid var(--ink-05);
  border-bottom: 1px solid var(--ink-05);
}

#experience h2 {
  max-width: var(--max-w);
  margin: 0 auto 2.5rem;
}

.exp-list{
  display:flex;
  flex-direction:column;
  max-width: var(--max-w);
  margin: 0 auto;
  width: 100%;
}

.exp-row{
  display:grid;
  grid-template-columns:240px 1fr 200px;
  gap:2rem;
  align-items:baseline;
  padding:2.2rem 0;border-bottom:1px solid var(--ink-05);
  transition:background var(--dur-fast) ease-out;
  position:relative;overflow:hidden;
}
.exp-row:first-child{border-top:1px solid var(--ink-05)}
.exp-row:hover{background:rgba(255,255,255,.4)}

.exp-row__period{font-family:var(--mono);font-size:0.95rem;color:var(--ink-30);padding-top:3px;position:relative;z-index:1}
.exp-row__content{display:flex;flex-direction:column;gap:6px;position:relative;z-index:1}
.exp-row__role{font-size:1.5rem;font-weight:700;letter-spacing:-.02em}
.exp-row__company{font-family:var(--mono);font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}
.exp-row__desc{
  font-family: var(--sans) !important;
  font-size: 1.05rem !important;
  color: #4A4A4A !important;
  margin-top:.4rem;
  line-height: 1.65 !important;
  max-width: 70ch;
}
.exp-row__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:.8rem}
.exp-row__tags .tag {font-size: 0.85rem;}
.exp-row__location{font-family:var(--mono);font-size:0.95rem;color:var(--ink-30);text-align:right;padding-top:3px;position:relative;z-index:1}

.exp-bg-placeholder {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 50%;
  mask-image: linear-gradient(to right, transparent 0%, black 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 100%);
  opacity: 0.8;
  z-index: 0;
  pointer-events: none;
}

.tag{
  font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;
  padding:3px 9px;border-radius:999px;border:1px solid var(--ink-15);color:var(--ink-50);
  transition:all var(--dur-fast) ease-out;
}
.tag:hover{border-color:var(--accent);color:var(--accent)}

/* --- Labs / Projects (Bento) --------------------------------------- */
@media (min-width: 1024px) {
  .labs-grid {
    display: grid;
    grid-template-columns: 1.3fr .7fr;
    grid-template-rows: auto auto auto;
    gap: 16px;
  }
  .lab-card {
    height: 100%;
  }
  .lab-card--featured {
    grid-column: 1;
    grid-row: 1/3;
  }
  .lab-card--ideas {
    grid-column: 2;
    grid-row: 1;
  }
  .lab-card--content {
    grid-column: 2;
    grid-row: 2/4;
  }
  .lab-card--github {
    grid-column: 1;
    grid-row: 3;
  }
}

@media (max-width: 1023px) {
  .labs-grid {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .lab-card {
    width: 100%;
  }
}

/* Double-bezel card */
.lab-card{
  padding:6px;background:var(--ink-05);border:1px solid rgba(10,10,10,.06);
  border-radius:var(--radius-xl);
  transition:all var(--dur-normal) var(--ease-out-expo);
  position:relative;overflow:hidden;
  display: flex;
  flex-direction: column;
}
.lab-card:hover{
  border-color:rgba(10,10,10,.12);
  box-shadow:0 20px 60px -15px rgba(10,10,10,.12);
  transform:translateY(-3px);
}
.lab-card__inner{
  background:#fff;border-radius:calc(var(--radius-xl) - 4px);
  padding:clamp(1.2rem,2.2vw,1.8rem);
  display:flex;flex-direction:column;gap:.7rem;height:100%;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.6);
}

.lab-card--dark .lab-card__inner{background:var(--ink);color:#fff;box-shadow:inset 0 1px 1px rgba(255,255,255,.08)}
.lab-card--dark .lab-card__label{color:rgba(255,255,255,.35)}
.lab-card--dark .lab-card__desc{color:rgba(255,255,255,.55)}

.lab-card--accent .lab-card__inner{background:var(--accent);color:#fff;box-shadow:inset 0 1px 1px rgba(255,255,255,.15)}
.lab-card--accent .lab-card__label{color:rgba(255,255,255,.45)}
.lab-card--accent .lab-card__desc{color:rgba(255,255,255,.65)}

.lab-card--featured{grid-row:1/3}

.lab-card__label{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-30)}
.lab-card__title{font-family:var(--serif);font-size:clamp(1.2rem,1.8vw,1.5rem);font-weight:700;letter-spacing:-.015em;line-height:1.15}
.lab-card--featured .lab-card__title{font-size:clamp(1.4rem,2.2vw,1.8rem)}
.lab-card__desc{
  font-family: var(--sans) !important;
  font-size: 0.84rem !important;
  color: #4A4A4A;
  line-height: 1.65 !important;
}

.lab-card--dark .lab-card__desc {
  color: rgba(255, 255, 255, 0.7) !important;
}

.lab-card__visual{flex-grow:1;min-height:80px;border-radius:var(--radius-md);overflow:hidden;margin-top:.4rem}
.lab-card--featured .lab-card__visual{max-height:180px !important}
.lab-card__visual img{width:100%;height:100%;object-fit:cover}
.lab-card--dark .lab-card__visual{background:rgba(255,255,255,.05)}
.lab-card--accent .lab-card__visual{background:rgba(255,255,255,.12)}

.lab-card__arrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.8rem;font-weight:600;margin-top:auto;padding-top:.4rem;
  opacity:0;transform:translateX(-8px);
  transition:all var(--dur-fast) ease-out;
}
.lab-card:hover .lab-card__arrow{opacity:1;transform:translateX(0)}

/* Audio player */
.lab-card__audio{margin-top:auto;padding-top:.5rem}
.lab-card__audio audio{
  width:100%;height:36px;border-radius:999px;
  filter:sepia(.2) saturate(1.2);
}

/* --- Skills -------------------------------------------------------- */
.skills-wrap{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.skill-pill{
  font-size:.8rem;font-weight:500;padding:9px 18px;
  border-radius:999px;border:1px solid var(--ink-15);color:var(--ink-50);
  transition:all var(--dur-fast) ease-out;cursor:default;white-space:nowrap;
}
.skill-pill:hover{border-color:var(--ink);color:var(--ink);background:#fff;box-shadow:0 6px 16px -8px rgba(10,10,10,.15);transform:translateY(-1px)}
.skill-pill--hl{border-color:var(--accent-border);color:var(--accent);background:var(--accent-bg)}
.skill-pill--hl:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

.edu-row{display:flex;gap:2rem;flex-wrap:wrap;margin-top:2.5rem;justify-content:center}
.edu-item{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--ink-50)}
.edu-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);flex-shrink:0}

/* --- Contact Form (Brutalist) -------------------------------------- */
.contact{padding:clamp(4rem,8vw,7rem) 0}
.contact__inner{
  max-width:700px;
  margin:0 auto;
}
.contact__intro{margin-bottom:2.5rem;text-align:center}
.contact__intro p{margin-top:.6rem}

.contact-form{display:flex;flex-direction:column;gap:2rem}

.form-group{position:relative}
.form-group label{
  display:block;
  font-family:var(--serif);font-size:1.1rem;font-weight:600;
  letter-spacing:-.01em;
  margin-bottom:.6rem;color:var(--ink);
}
.form-group input,
.form-group textarea{
  width:100%;
  padding:12px 0;
  font-family:var(--sans);font-size:.95rem;
  color:var(--ink);
  background:transparent;
  border:none;
  border-bottom:3px solid var(--ink);
  outline:none;
  transition:border-color var(--dur-normal) var(--ease-out-expo);
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--ink-30)}
.form-group input:focus,
.form-group textarea:focus{border-bottom-color:var(--accent)}

.form-group textarea{
  min-height:120px;resize:vertical;
  border-bottom-width:3px;
}

.form-submit{
  display:block;width:100%;
  padding:18px 32px;
  font-family:var(--sans);font-size:1rem;font-weight:700;
  letter-spacing:.02em;text-transform:uppercase;
  color:#fff;background:var(--ink);
  border:none;border-radius:var(--radius-sm);
  cursor:pointer;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.08);
  transition:all var(--dur-normal) var(--ease-out-expo);
}
.form-submit:hover{
  background:var(--accent);
  box-shadow:0 18px 40px -10px rgba(201,80,60,.35),inset 0 1px 0 rgba(255,255,255,.15);
  transform:translateY(-2px);
}
.form-submit:active{transform:scale(.98)}

/* --- Footer -------------------------------------------------------- */
.footer{padding:4rem 0 2.5rem;border-top:1px solid var(--ink-05);margin-top:0}

.footer__grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr;
  gap:3rem;margin-bottom:3rem;
}
.footer__brand{font-family:var(--serif);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}
.footer__brand-desc{font-size:.82rem;color:var(--ink-50);max-width:300px;line-height:1.5}

.footer__heading{
  font-family:var(--mono);font-size:.62rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.14em;color:var(--ink-30);margin-bottom:1rem;
}
.footer__links{display:flex;flex-direction:column;gap:10px}
.footer__link{font-size:.82rem;color:var(--ink-50);transition:color var(--dur-fast) ease-out}
.footer__link:hover{color:var(--accent)}

/* Glossary */
.glossary{
  margin-top:2.5rem;padding-top:2rem;
  border-top:1px solid var(--ink-05);
}
.glossary__title{
  font-family:var(--serif);font-size:1.1rem;font-weight:700;
  margin-bottom:1.2rem;
}
.glossary__list{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1rem;
}
.glossary__item{
  padding:1rem;
  background:#fff;border:1px solid var(--ink-08);border-radius:var(--radius-md);
  transition:all var(--dur-normal) var(--ease-out-expo);
}
.glossary__item:hover{border-color:var(--ink-15);box-shadow:0 8px 20px -8px rgba(0,0,0,.08)}
.glossary__term{
  font-family:var(--mono);font-size:.7rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent);margin-bottom:.4rem;
}
.glossary__def{font-size:.8rem;color:var(--ink-50);line-height:1.5}

.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:1.5rem;border-top:1px solid var(--ink-05);
}
.footer__copy{font-size:.7rem;color:var(--ink-30)}
.footer__locale{font-size:.7rem;color:var(--ink-30);display:flex;align-items:center;gap:6px}
.footer__locale-dot{width:5px;height:5px;border-radius:50%;background:var(--accent)}

/* --- Animations ---------------------------------------------------- */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.fade-up{opacity:0;animation:fadeUp var(--dur-slow) var(--ease-out-expo) forwards}
.fade-up-d1{animation-delay:.1s}
.fade-up-d2{animation-delay:.2s}
.fade-up-d3{animation-delay:.3s}
.fade-up-d4{animation-delay:.4s}

/* --- Responsive ---------------------------------------------------- */
@media(max-width:1023px){
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:7rem;gap:2rem}
  .hero__copy{padding-right:0}
  .hero__images{height:280px}
  .exp-row{grid-template-columns:1fr;gap:.5rem}
  .exp-row__period{order:-1}
  .exp-row__location{text-align:left}
  .labs-grid{grid-template-columns:1fr}
  .lab-card--featured{grid-row:auto}
  .footer__grid{grid-template-columns:1fr;gap:2rem}
  .trusted__logos{gap:1.5rem}
}

@media (max-width: 768px) {
  .archives-grid,
  .labs-grid,
  .saas-grid {
    grid-template-columns: 1fr;
  }
  .interests-header {
    flex-direction: column;
    align-items: flex-start;
    padding-top: 140px;
  }
}

@media(max-width:640px){
  .nav__link{display:none}
  .hero__images{grid-template-columns:1fr 1fr;grid-template-rows:1fr;height:200px}
  .hero__img--tall{grid-row:auto}
  .display{font-size:2rem}
  .section{padding:3rem 0}
  .footer__bottom{flex-direction:column;gap:.8rem;align-items:flex-start}
  .platforms__grid{gap:.8rem}
  .glossary__list{grid-template-columns:1fr}
}

/* --- Archives / Playground ---------------------------------------- */
.archives-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1.5rem;
}
.archive-card {
  background: #fff;
  border: 1px solid var(--ink-08);
  border-radius: 12px;
  padding: 1.2rem;
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  box-shadow: 0 2px 8px -2px rgba(0,0,0,.04);
}
.archive-card:hover {
  transform: translateY(-4px);
  border-color: var(--ink-15);
  box-shadow: 0 8px 20px -6px rgba(0,0,0,.1);
}
.archive-card-img-placeholder {
  width: 100%;
  height: 140px;
  border-radius: 8px;
  margin-bottom: 0.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
/* Game cards — dark gradient + arcade feel */
.archive-card--game .archive-card-img-placeholder {
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 40%, #0f3460 100%);
}
.archive-card--game .archive-card-img-placeholder::after {
  content: "🎮";
  font-size: 2.5rem;
  filter: grayscale(0.3);
  opacity: 0.7;
}
/* Web cards — warm gradient + globe */
.archive-card--web .archive-card-img-placeholder {
  background: linear-gradient(135deg, #2d1b0e 0%, #3d2a1a 50%, #1a0f05 100%);
}
.archive-card--web .archive-card-img-placeholder::after {
  content: "🌐";
  font-size: 2.5rem;
  opacity: 0.7;
}
.archive-card__year {
  font-family: var(--mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  color: var(--ink-30);
  letter-spacing: 0.05em;
}
.archive-card__title {
  font-family: var(--sans);
  font-size: 1rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.archive-card__desc {
  font-size: 0.82rem;
  color: var(--ink-50);
  line-height: 1.45;
}

/* --- Interests (Beatmaking) ---------------------------------------- */
.section-interests {
  background-color: #EEE9E3 !important;
  color: #000000 !important;
  padding: 4rem 2rem;
  border-radius: 16px;
  margin-bottom: 4rem;
  position: relative;
}
.section-interests h2,
.section-interests p,
.section-interests span,
.section-interests .beat-title {
  color: #000000 !important;
}
.interests-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 2.5rem;
  gap: 1.5rem;
}
@media (min-width: 769px) {
  .interests-header > div {
    padding-right: 200px;
  }
}
@media (max-width: 768px) {
  .interests-header > div {
    padding-right: 0;
  }
}
.interests-logo img {
  height: 120px !important;
  width: auto !important;
  position: absolute;
  right: 20px;
  top: 20px;
  z-index: 10;
}
@media (max-width: 768px) {
  .interests-logo img {
    left: 50%;
    transform: translateX(-50%);
    right: auto;
    top: 20px;
  }
}
.beats-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.beat-track {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  background: rgba(10, 10, 10, 0.05); /* subtle dark transparent overlay */
  padding: 1.2rem;
  border-radius: 12px;
  border: 1px solid rgba(10, 10, 10, 0.1);
}
.beat-title {
  font-family: var(--mono);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--ink);
}
.beat-player-row {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.beat-play-btn {
  background: var(--ink);
  color: white;
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  transition: all 0.2s ease;
}
.beat-play-btn:hover {
  background: var(--ink-70);
  transform: scale(1.05);
}
.beat-play-btn:active {
  transform: scale(0.95);
}
.beat-track audio {
  width: 100%;
}
.beat-track audio::-webkit-media-controls-panel {
  background-color: #ffeedd;
}
.beat-track audio::-webkit-media-controls-current-time-display,
.beat-track audio::-webkit-media-controls-time-remaining-display {
  color: #8b2500;
}
.beat-track audio::-webkit-media-controls-play-button,
.beat-track audio::-webkit-media-controls-mute-button {
  filter: sepia(1) saturate(5) hue-rotate(340deg);
}

/* --- Scrollbar ----------------------------------------------------- */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--ink-15);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--ink-30)}

/* --- Subtitles / Descriptions reference style ---------------------- */
.body-lg.muted {
  font-size: 1.5rem !important;
  font-weight: 500 !important;
  line-height: 1.375 !important;
  letter-spacing: 0.02em !important;
  color: #525252 !important;
  font-family: sans-serif !important;
}

/* --- Vision Section ------------------------------------------------ */
.vision {
  padding: 6rem var(--gutter) !important;
  border-bottom: 1px solid var(--ink-05);
}
.vision-content {
  max-width: 900px;
  margin: 0 auto;
}
.vision-editorial {
  font-size: clamp(2rem, 5vw, 4rem) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.04em !important;
  font-family: var(--sans) !important;
  color: #000 !important;
}

.serif-italic {
  font-family: 'Playfair Display', Garamond, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
}

.color-blue {
  color: #0A2540 !important;
  font-weight: 600 !important;
}

.color-red {
  color: #C5302E !important;
  font-style: normal !important;
}

.highlight-color { color: #D95D39; }

/* Pilules (Dé-zoom & Relief) */
.vision-pill {
  display: inline-block;
  vertical-align: middle;
  height: 1.5em;
  width: 4.5em;
  object-fit: cover;
  object-position: center;
  border-radius: 50px;
  margin: 0 12px;
  transition: opacity 0.5s ease-in-out;
  box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

.pill-tilt-left { transform: rotate(-4deg); }
.pill-tilt-right { transform: rotate(3deg); }

.spin-star {
  display: inline-block;
  color: #F07167;
  animation: spin 5s linear infinite;
}
@keyframes spin { 100% { transform: rotate(360deg); } }

.float-flame {
  display: inline-block;
  animation: float 3s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

.contact-title {
  font-size: clamp(2.5rem, 5vw, 4rem) !important;
  text-align: center;
  white-space: nowrap; /* Empêche le texte de passer sur deux lignes */
  letter-spacing: -0.02em;
}

.sans-bold {
  font-family: -apple-system, BlinkMacSystemFont, sans-serif !important;
  font-style: normal !important;
  font-weight: 800 !important;
}
