/* ============================================================
   MindX Growth & Excellence Units 2026 — Landing
   Editorial luxury / premium recruitment microsite
   ============================================================ */

/* ---------- TOKENS ---------- */
:root, [data-theme="light"]{
  /* Surfaces — crisp cream + high-contrast stone. */
  --bg:            #FBF7EE;
  --bg-2:          #EDE5D0;
  --surface:       #FFFFFF;
  --surface-2:     #F3EDDB;
  --border:        #D5CBB0;
  --divider:       #C6BC9E;
  --hairline:      rgba(15,13,10,0.14);

  /* Ink — deep espresso graphite for stronger contrast. */
  --ink:           #100E0B;
  --ink-strong:    #050403;
  --ink-muted:     #57503F;
  --ink-faint:     #8E866F;

  /* Accents — richer antique gold, more saturated for CTAs. */
  --gold:          #9C7018;
  --gold-hover:    #7A5610;
  --gold-soft:     rgba(156,112,24,0.16);
  --mindx-red:     #C41B21;
  --mindx-red-soft:rgba(196,27,33,0.10);

  /* Type */
  --font-serif:    'Cormorant Garamond', 'EB Garamond', Georgia, 'Times New Roman', serif;
  --font-sans:     'Inter', 'Helvetica Neue', system-ui, -apple-system, sans-serif;

  /* Spacing (4px base) */
  --sp-1: .25rem; --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem;
  --sp-5: 1.25rem; --sp-6:1.5rem; --sp-8:2rem; --sp-10:2.5rem;
  --sp-12:3rem; --sp-16:4rem; --sp-20:5rem; --sp-24:6rem; --sp-32:8rem;

  /* Radii */
  --r-sm:.25rem; --r-md:.5rem; --r-lg:.75rem; --r-xl:1.25rem;

  /* Shadows — deeper for editorial depth. */
  --shadow-sm: 0 1px 2px rgba(15,10,3,.06);
  --shadow-md: 0 10px 30px rgba(20,15,5,.10), 0 3px 6px rgba(20,15,5,.05);
  --shadow-lg: 0 30px 80px rgba(20,15,5,.15), 0 8px 16px rgba(20,15,5,.06);

  /* Content widths */
  --w-narrow: 720px;
  --w-default: 1120px;
  --w-wide: 1280px;

  /* Fluid type */
  --t-xs:   clamp(.75rem, .7rem + .2vw, .82rem);
  --t-sm:   clamp(.85rem, .8rem + .25vw, .95rem);
  --t-base: clamp(1rem, .95rem + .25vw, 1.09rem);
  --t-lg:   clamp(1.125rem, 1rem + .5vw, 1.35rem);
  --t-xl:   clamp(1.5rem, 1.2rem + 1.25vw, 2.25rem);
  --t-2xl:  clamp(2rem, 1.4rem + 2.6vw, 3.5rem);
  --t-3xl:  clamp(2.75rem, 1.4rem + 4.6vw, 5.5rem);
  --t-hero: clamp(3rem, 1rem + 7vw, 7.5rem);

  --transition-slow: 480ms cubic-bezier(.16,1,.3,1);
  --transition:      260ms cubic-bezier(.16,1,.3,1);
  --transition-fast: 160ms cubic-bezier(.16,1,.3,1);
}

[data-theme="dark"]{
  --bg:            #0E0D0B;
  --bg-2:          #131210;
  --surface:       #17150F;
  --surface-2:     #1D1B14;
  --border:        #2A2820;
  --divider:       #24221B;
  --hairline:      rgba(240,232,214,0.08);

  --ink:           #F1EBD9;
  --ink-strong:    #FCF8EC;
  --ink-muted:     #A29B87;
  --ink-faint:     #6B6553;

  --gold:          #C79A55;
  --gold-hover:    #E1B673;
  --gold-soft:     rgba(199,154,85,0.15);
  --mindx-red:     #E31E24;
  --mindx-red-soft:rgba(227,30,36,0.14);

  --shadow-sm: 0 1px 2px rgba(0,0,0,.35);
  --shadow-md: 0 8px 24px rgba(0,0,0,.4), 0 2px 4px rgba(0,0,0,.35);
  --shadow-lg: 0 22px 60px rgba(0,0,0,.55), 0 6px 12px rgba(0,0,0,.35);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{
  scroll-behavior:smooth;
  scroll-padding-top:96px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
body{
  min-height:100dvh;
  font-family:var(--font-sans);
  font-size:var(--t-base);
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  transition:background var(--transition-slow), color var(--transition-slow);
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}
ul{list-style:none}
input,button,textarea,select{font:inherit;color:inherit}
button{background:none;border:none;cursor:pointer;color:inherit}
::selection{background:var(--gold-soft);color:var(--ink-strong)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:var(--r-sm)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* ---------- LAYOUT ---------- */
.section-inner{
  max-width:var(--w-default);
  margin:0 auto;
  padding-left:clamp(var(--sp-5), 5vw, var(--sp-16));
  padding-right:clamp(var(--sp-5), 5vw, var(--sp-16));
}

.section-eyebrow{
  display:inline-flex;align-items:center;gap:var(--sp-3);
  font-size:var(--t-xs);
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:var(--sp-6);
}
.section-eyebrow::before{
  content:"";width:28px;height:1px;
  background:var(--gold);opacity:.9;
}
.section-eyebrow--gold{color:var(--gold)}
.section-eyebrow--gold::before{background:var(--gold);opacity:1}

.section-title{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:var(--t-2xl);
  line-height:1.08;
  letter-spacing:-.015em;
  color:var(--ink-strong);
  text-wrap:balance;
}
.section-title em{
  font-style:italic;
  color:var(--gold);
  font-weight:400;
}

.lede{
  font-size:var(--t-lg);
  line-height:1.55;
  color:var(--ink-muted);
  max-width:52ch;
  margin-top:var(--sp-5);
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  font-family:var(--font-sans);
  font-weight:500;
  font-size:var(--t-sm);
  letter-spacing:.02em;
  padding:.85rem 1.5rem;
  border-radius:var(--r-md);
  border:1px solid transparent;
  transition:all var(--transition);
  cursor:pointer;
  white-space:nowrap;
  line-height:1;
}
.btn--primary{
  background:var(--ink-strong);
  color:var(--bg);
  border-color:var(--ink-strong);
}
.btn--primary:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:var(--shadow-md);
}
.btn--ghost{
  background:transparent;
  color:var(--ink-strong);
  border-color:var(--border);
}
.btn--ghost:hover{
  border-color:var(--ink);
  background:var(--surface);
}
.btn--lg{padding:1.1rem 1.8rem;font-size:var(--t-sm)}
.btn--sm{padding:.55rem 1rem;font-size:var(--t-xs)}
.btn--block{width:100%}

/* ---------- HEADER ---------- */
.site-header{
  position:sticky;top:0;z-index:80;
  background:color-mix(in oklab, var(--bg) 78%, transparent);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid transparent;
  transition:border-color var(--transition), background var(--transition), transform var(--transition-slow);
}
.site-header.is-scrolled{
  border-color:var(--hairline);
  background:color-mix(in oklab, var(--bg) 94%, transparent);
  box-shadow:0 1px 20px rgba(20,15,5,.06);
}
[data-theme="dark"] .site-header.is-scrolled{box-shadow:0 1px 20px rgba(0,0,0,.4)}
.header-inner{
  max-width:var(--w-wide);
  margin:0 auto;
  padding:var(--sp-4) clamp(var(--sp-5), 5vw, var(--sp-16));
  display:flex;align-items:center;gap:var(--sp-6);
}
.brand{
  display:inline-flex;align-items:center;gap:var(--sp-4);
  font-family:var(--font-serif);
}
.brand-logo{
  height:32px;width:auto;
  transition:opacity var(--transition);
}
.brand-logo--dark{display:none}
[data-theme="dark"] .brand-logo--light{display:none}
[data-theme="dark"] .brand-logo--dark{display:block}

.brand-divider{
  width:1px;height:22px;
  background:var(--divider);
  display:none;
}
.brand-tag{
  font-family:var(--font-sans);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-muted);
  font-weight:500;
  display:none;
}
.brand-year{color:var(--gold)}

.site-nav{
  margin-left:auto;
  display:flex;align-items:center;gap:var(--sp-8);
}
.site-nav a{
  font-size:var(--t-sm);
  color:var(--ink-muted);
  font-weight:500;
  position:relative;
}
.site-nav a:hover{color:var(--ink-strong)}
.site-nav a::after{
  content:"";
  position:absolute;left:0;right:100%;bottom:-6px;height:1px;
  background:var(--gold);
  transition:right var(--transition);
}
.site-nav a:hover::after{right:0}

.header-actions{
  display:flex;align-items:center;gap:var(--sp-3);
}
.theme-toggle{
  width:36px;height:36px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink-muted);
  border-radius:var(--r-md);
  transition:all var(--transition);
}
.theme-toggle:hover{color:var(--ink-strong);background:var(--surface)}

.menu-toggle{
  display:none;
  width:36px;height:36px;
  flex-direction:column;justify-content:center;gap:5px;
  padding:8px;
  margin-left:auto;
}
.menu-toggle span{
  display:block;width:100%;height:1.5px;background:var(--ink-strong);transition:all var(--transition);
}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media (min-width: 900px){
  .brand-divider,.brand-tag{display:inline-block}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:clamp(var(--sp-16), 12vw, var(--sp-32)) 0 clamp(var(--sp-20), 12vw, var(--sp-32));
  overflow:hidden;
  isolation:isolate;
}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:-1}
.hero-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(80px);
  opacity:.5;
  mix-blend-mode:multiply;
}
[data-theme="dark"] .hero-orb{mix-blend-mode:screen;opacity:.28}
.hero-orb--1{
  width:620px;height:620px;
  background:radial-gradient(circle,var(--gold-soft),transparent 68%);
  top:-180px;left:-180px;
  opacity:.9;
}
.hero-orb--2{
  width:720px;height:720px;
  background:radial-gradient(circle, var(--mindx-red-soft),transparent 62%);
  bottom:-220px;right:-180px;
  opacity:.42;
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--hairline) 1px, transparent 1px),
    linear-gradient(90deg, var(--hairline) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, black 35%, transparent 78%);
  -webkit-mask-image:radial-gradient(ellipse at center, black 35%, transparent 78%);
  opacity:.7;
}
[data-theme="dark"] .hero-grid{opacity:.45}
.hero-inner{
  max-width:var(--w-default);
  margin:0 auto;
  padding-left:clamp(var(--sp-5), 5vw, var(--sp-16));
  padding-right:clamp(var(--sp-5), 5vw, var(--sp-16));
  position:relative;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:var(--sp-3);
  font-size:var(--t-xs);
  font-weight:600;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink);
  padding:.5rem .95rem .5rem .55rem;
  border:1px solid var(--divider);
  border-radius:999px;
  background:var(--surface);
  box-shadow:var(--shadow-sm);
  margin-bottom:var(--sp-8);
}
.eyebrow-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 4px var(--gold-soft);
  animation:pulse 2.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px var(--gold-soft)}
  50%{box-shadow:0 0 0 8px transparent}
}

.hero-title{
  font-family:var(--font-serif);
  font-weight:400;
  font-size:var(--t-hero);
  line-height:.98;
  letter-spacing:-.03em;
  color:var(--ink-strong);
  margin-bottom:var(--sp-8);
  text-wrap:balance;
  max-width:14ch;
}
.hero-title em{
  font-style:italic;
  color:var(--gold);
  font-weight:500;
}

.hero-sub{
  font-size:var(--t-lg);
  line-height:1.55;
  color:var(--ink-muted);
  max-width:56ch;
  margin-bottom:var(--sp-10);
}

.hero-cta{
  display:flex;flex-wrap:wrap;gap:var(--sp-3);
  margin-bottom:var(--sp-16);
}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:1px;
  background:var(--divider);
  border:1px solid var(--divider);
  border-radius:var(--r-lg);
  overflow:hidden;
  max-width:920px;
}
.stat{
  background:color-mix(in oklab, var(--bg) 70%, var(--surface));
  padding:var(--sp-6) var(--sp-5);
}
.stat-num{
  font-family:var(--font-serif);
  font-size:clamp(2rem, 1.4rem + 1.8vw, 2.8rem);
  font-weight:500;
  color:var(--ink-strong);
  line-height:1;
  letter-spacing:-.02em;
  margin-bottom:var(--sp-2);
  display:flex;align-items:baseline;gap:var(--sp-2);
  flex-wrap:wrap;
}
.stat-num span{
  font-size:var(--t-xs);
  font-weight:500;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--ink-muted);
  font-family:var(--font-sans);
}
.stat-label{
  font-size:var(--t-xs);
  color:var(--ink-muted);
  letter-spacing:.06em;
}

.hero-scroll{
  position:absolute;
  bottom:2rem;right:clamp(var(--sp-5), 5vw, var(--sp-16));
  display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);
  color:var(--ink-faint);
  font-size:var(--t-xs);
  letter-spacing:.24em;
  text-transform:uppercase;
}
.hero-scroll-line{
  width:1px;height:64px;
  background:linear-gradient(to bottom, transparent, var(--ink-faint));
  position:relative;overflow:hidden;
}
.hero-scroll-line::after{
  content:"";
  position:absolute;top:-16px;left:0;width:1px;height:16px;
  background:var(--gold);
  animation:scrollDown 2.4s cubic-bezier(.55,0,.35,1) infinite;
}
@keyframes scrollDown{
  0%{top:-16px}
  100%{top:64px}
}
@media (max-width: 760px){
  .hero-scroll{display:none}
}

/* ---------- CONTEXT ---------- */
.context{
  padding:clamp(var(--sp-20), 12vw, var(--sp-32)) 0;
  background:var(--bg-2);
  border-top:1px solid var(--divider);
  border-bottom:1px solid var(--divider);
  position:relative;
}
.context::before{
  content:"";
  position:absolute;top:-1px;left:35%;right:35%;height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
  opacity:.7;
}
.context-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1.15fr);
  gap:clamp(var(--sp-8), 6vw, var(--sp-24));
  align-items:start;
}
.context-list{
  margin-top:var(--sp-8);
  display:flex;flex-direction:column;gap:var(--sp-3);
}
.context-list li{
  display:flex;gap:var(--sp-3);
  font-size:var(--t-base);
  color:var(--ink);
  padding-bottom:var(--sp-3);
  border-bottom:1px solid var(--hairline);
}
.context-list li:last-child{border:none;padding-bottom:0}
.context-list span{color:var(--gold);flex-shrink:0}

@media (max-width: 860px){
  .context-grid{grid-template-columns:1fr}
}

/* ---------- TEAMS ---------- */
.teams{
  padding:clamp(var(--sp-20), 12vw, var(--sp-32)) 0;
}
.teams-intro{
  max-width:var(--w-narrow);
  margin-bottom:clamp(var(--sp-12), 8vw, var(--sp-20));
}
.teams-title{margin-top:0}

.team{
  display:grid;
  grid-template-columns:120px minmax(0, 1fr);
  gap:clamp(var(--sp-6), 4vw, var(--sp-16));
  padding:clamp(var(--sp-10), 6vw, var(--sp-16)) 0;
  border-top:1px solid var(--divider);
  align-items:start;
  position:relative;
}
.team:last-of-type{border-bottom:1px solid var(--divider)}

/* Alternate rhythm: odd teams have image side on left, even on right — here we use offset */
.team--02, .team--04{
  background:linear-gradient(to right, transparent 0%, var(--surface-2) 15%, var(--surface-2) 85%, transparent 100%);
  margin-left:calc(-1 * clamp(var(--sp-5), 5vw, var(--sp-16)));
  margin-right:calc(-1 * clamp(var(--sp-5), 5vw, var(--sp-16)));
  padding-left:clamp(var(--sp-5), 5vw, var(--sp-16));
  padding-right:clamp(var(--sp-5), 5vw, var(--sp-16));
  border-color:transparent;
}
.team--02 + .team, .team--04 + .team{border-top-color:var(--divider)}

.team-number{
  position:sticky;top:120px;
  display:flex;flex-direction:column;align-items:flex-start;gap:var(--sp-4);
}
.team-num-digit{
  font-family:var(--font-serif);
  font-size:clamp(2.5rem, 1rem + 4vw, 4rem);
  font-weight:500;
  color:var(--gold);
  line-height:1;
  letter-spacing:-.02em;
}
.team-num-line{
  width:40px;height:1px;background:var(--gold);opacity:.7;
}

.team-content{max-width:820px}

.team-name{
  margin-bottom:var(--sp-4);
  display:flex;flex-direction:column;gap:var(--sp-2);
}
.team-name-en{
  font-family:var(--font-serif);
  font-size:var(--t-xl);
  font-weight:500;
  color:var(--ink-strong);
  letter-spacing:-.015em;
  line-height:1.15;
}
.team-name-vi{
  font-size:var(--t-sm);
  color:var(--ink-muted);
  letter-spacing:.02em;
}

.team-tagline{
  font-family:var(--font-serif);
  font-style:italic;
  font-size:var(--t-lg);
  color:var(--ink);
  padding:var(--sp-4) 0;
  border-top:1px solid var(--hairline);
  border-bottom:1px solid var(--hairline);
  margin-bottom:var(--sp-6);
}

.team-body{
  display:grid;
  grid-template-columns:minmax(0, 1.35fr) minmax(0, 1fr);
  gap:var(--sp-8);
  margin-bottom:var(--sp-6);
}
@media (max-width: 720px){
  .team-body{grid-template-columns:1fr;gap:var(--sp-6)}
}
.team-block h4{
  font-size:var(--t-xs);
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:var(--sp-4);
}
.team-block ul{
  display:flex;flex-direction:column;gap:var(--sp-3);
}
.team-block ul li{
  font-size:var(--t-base);
  color:var(--ink);
  padding-left:var(--sp-5);
  position:relative;
  line-height:1.5;
}
.team-block ul li::before{
  content:"";
  position:absolute;left:0;top:.75em;
  width:10px;height:1px;background:var(--gold);
}
.team-block strong{color:var(--ink-strong);font-weight:600}

.pill-list{flex-direction:row!important;flex-wrap:wrap!important;gap:var(--sp-2)!important}
.pill-list li{
  display:inline-flex;align-items:center;
  padding:.4rem .8rem !important;
  font-size:var(--t-xs)!important;
  color:var(--ink)!important;
  border:1px solid var(--border);
  border-radius:999px;
  background:color-mix(in oklab, var(--surface) 40%, transparent);
  line-height:1.2!important;
}
.pill-list li::before{display:none!important}

.team-highlight{
  display:flex;align-items:flex-start;gap:var(--sp-3);
  padding:var(--sp-4) var(--sp-5);
  background:var(--gold-soft);
  border-left:3px solid var(--gold);
  border-radius:0 var(--r-md) var(--r-md) 0;
  color:var(--ink);
  font-size:var(--t-sm);
  line-height:1.5;
  margin-bottom:var(--sp-6);
}
.team-highlight > .highlight-dot{margin-top:.55em}
.team-highlight > span:not(.highlight-dot){flex:1;min-width:0}
.highlight-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}
.team-highlight strong{color:var(--ink-strong);font-weight:600}
.team-highlight--strong{
  background:linear-gradient(90deg, var(--gold-soft) 0%, color-mix(in oklab, var(--gold-soft) 45%, transparent) 100%);
  border-left-width:3px;
  font-size:var(--t-base);
  line-height:1.5;
}
.team-highlight--strong strong{color:var(--gold);font-weight:700;white-space:nowrap}

.team-cta{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  font-size:var(--t-sm);
  color:var(--ink-strong);
  padding:.5rem 0;
  border-bottom:1px solid var(--ink-strong);
  font-weight:500;
  transition:all var(--transition);
}
.team-cta:hover{
  color:var(--gold);border-color:var(--gold);
  gap:var(--sp-3);
}

/* Mid CTA */
.mid-cta{
  margin:clamp(var(--sp-12), 6vw, var(--sp-16)) 0;
  padding:clamp(var(--sp-8), 5vw, var(--sp-12));
  background:linear-gradient(135deg, var(--ink-strong) 0%, #2A2620 100%);
  color:#F7F4EC;
  border-radius:var(--r-xl);
  position:relative;overflow:hidden;
}
[data-theme="dark"] .mid-cta{
  background:linear-gradient(135deg, #F5EFDC 0%, #E8DFC1 100%);
  color:#1A1815;
}
[data-theme="dark"] .mid-cta .mid-cta-title{color:#1A1815}
[data-theme="dark"] .mid-cta .mid-cta-eyebrow{color:#8A6A2E}
.mid-cta::before{
  content:"";position:absolute;top:-40%;right:-10%;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,var(--gold-soft),transparent 65%);
  filter:blur(40px);
}
.mid-cta-inner{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;gap:var(--sp-8);
  flex-wrap:wrap;
}
.mid-cta-eyebrow{
  font-size:var(--t-xs);letter-spacing:.24em;text-transform:uppercase;
  color:#C79A55;margin-bottom:var(--sp-3);font-weight:600;
}
.mid-cta-title{
  font-family:var(--font-serif);
  font-size:var(--t-xl);
  font-weight:400;
  color:inherit;
  line-height:1.2;
  max-width:26ch;
}
.mid-cta-title em{
  font-style:italic;
  color:#E1B673;
  font-weight:500;
}
[data-theme="dark"] .mid-cta-title em{color:#8A6A2E}
.mid-cta .btn--primary{
  background:var(--gold);
  border-color:var(--gold);
  color:#fff;
}
.mid-cta .btn--primary:hover{
  background:var(--gold-hover);
  border-color:var(--gold-hover);
}

@media (max-width: 720px){
  .team{grid-template-columns:1fr;gap:var(--sp-5)}
  .team-number{position:static;flex-direction:row;align-items:center}
  .team-num-line{width:80px}
}

/* ---------- WHY / BENTO ---------- */
.why{
  padding:clamp(var(--sp-20), 12vw, var(--sp-32)) 0;
  background:var(--bg-2);
  border-top:1px solid var(--divider);
  border-bottom:1px solid var(--divider);
  position:relative;
}
.why::before{
  content:"";
  position:absolute;top:-1px;left:35%;right:35%;height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
  opacity:.7;
}
.why-intro{
  max-width:var(--w-narrow);
  margin-bottom:clamp(var(--sp-10), 6vw, var(--sp-16));
}
.bento{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--sp-5);
}
.bento-item{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:clamp(var(--sp-6), 3vw, var(--sp-8));
  display:flex;flex-direction:column;
  gap:var(--sp-3);
  position:relative;overflow:hidden;
  transition:all var(--transition);
  box-shadow:var(--shadow-sm);
}
.bento-item:hover{
  border-color:var(--gold);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.bento-item::before{
  content:"";position:absolute;top:0;right:0;
  width:120px;height:120px;
  background:radial-gradient(circle at top right,var(--gold-soft),transparent 70%);
  opacity:0;transition:opacity var(--transition);
}
.bento-item:hover::before{opacity:1}
/* Deprecated modifiers — kept for backward-compat but no-op on desktop. */
.bento-item--wide,.bento-item--tall{grid-column:auto;grid-row:auto}
.bento-num{
  font-family:var(--font-serif);
  font-size:var(--t-lg);
  color:var(--gold);
  font-weight:600;
  letter-spacing:.02em;
  padding-bottom:var(--sp-6);
  position:relative;
}
.bento-num::after{
  content:"";
  position:absolute;left:0;bottom:var(--sp-3);
  width:24px;height:1px;
  background:var(--gold);
  opacity:.6;
}
.bento-item h3{
  font-family:var(--font-serif);
  font-size:var(--t-lg);
  font-weight:500;
  color:var(--ink-strong);
  margin:0 0 var(--sp-2) 0;
  letter-spacing:-.01em;
  line-height:1.2;
}
.bento-item p{
  font-size:var(--t-sm);
  color:var(--ink-muted);
  line-height:1.6;
  margin:0;
}
@media (max-width: 920px){
  .bento{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width: 560px){
  .bento{grid-template-columns:1fr;gap:var(--sp-4)}
}

/* ---------- PROFILE ---------- */
.profile{
  padding:clamp(var(--sp-20), 12vw, var(--sp-32)) 0;
}
.profile-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(var(--sp-8), 6vw, var(--sp-20));
  align-items:start;
}
.profile-list{
  display:flex;flex-direction:column;
  border-top:1px solid var(--divider);
}
.profile-list li{
  display:flex;align-items:flex-start;gap:var(--sp-4);
  padding:var(--sp-5) 0;
  border-bottom:1px solid var(--divider);
  font-size:var(--t-lg);
  color:var(--ink);
  font-family:var(--font-serif);
  line-height:1.4;
}
.profile-check{
  font-family:var(--font-sans);
  font-size:var(--t-sm);
  color:var(--gold);
  margin-top:.5em;
  flex-shrink:0;
  letter-spacing:.1em;
}
@media (max-width: 860px){
  .profile-grid{grid-template-columns:1fr}
}

/* ---------- REGISTER FORM ---------- */
.register{
  padding:clamp(var(--sp-20), 12vw, var(--sp-32)) 0;
  background:
    radial-gradient(ellipse at top left, var(--gold-soft), transparent 55%),
    radial-gradient(ellipse at bottom right, color-mix(in oklab, var(--ink-strong) 6%, transparent), transparent 60%),
    var(--bg-2);
  border-top:1px solid var(--divider);
  position:relative;
}
.register::before{
  content:"";
  position:absolute;top:-1px;left:35%;right:35%;height:1px;
  background:linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
  opacity:.7;
}
.register-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1.15fr);
  gap:clamp(var(--sp-8), 5vw, var(--sp-16));
  align-items:start;
}
.register-title{margin-bottom:var(--sp-4)}
.register-notes{
  margin-top:var(--sp-6);
  display:flex;flex-direction:column;gap:var(--sp-3);
  font-size:var(--t-sm);color:var(--ink-muted);
}
.register-notes li{display:flex;gap:var(--sp-3)}
.register-notes span{color:var(--gold)}

.register-contact{
  margin-top:var(--sp-10);
  padding-top:var(--sp-6);
  border-top:1px solid var(--divider);
}
.register-contact-label{
  font-size:var(--t-xs);
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:var(--sp-2);
}
.register-contact-mail{
  font-family:var(--font-serif);
  font-size:var(--t-lg);
  color:var(--ink-strong);
  border-bottom:1px solid var(--gold);
  padding-bottom:2px;
}
.register-contact-mail:hover{color:var(--gold)}

.register-form{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:clamp(var(--sp-6), 4vw, var(--sp-10));
  box-shadow:var(--shadow-lg);
  position:relative;
}
.form-title{
  font-family:var(--font-serif);
  font-size:var(--t-lg);
  color:var(--ink-strong);
  margin-bottom:var(--sp-6);
  padding-bottom:var(--sp-4);
  border-bottom:1px solid var(--hairline);
  letter-spacing:-.01em;
}

.field{margin-bottom:var(--sp-5)}
.field-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--sp-4);
}
.field-row .field{margin-bottom:var(--sp-5)}
@media (max-width: 560px){
  .field-row{grid-template-columns:1fr}
}
.field label{
  display:block;
  font-size:var(--t-xs);
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--ink-muted);
  margin-bottom:var(--sp-2);
}
.field label span[aria-hidden]{color:var(--gold)}
.field-hint{
  font-weight:400;text-transform:none;letter-spacing:.02em;
  color:var(--ink-faint);
  margin-left:var(--sp-1);
}
.field input,.field textarea{
  width:100%;
  padding:.85rem 1rem;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  font-size:var(--t-base);
  color:var(--ink);
  transition:all var(--transition);
  font-family:var(--font-sans);
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint)}
.field input:focus,.field textarea:focus{
  outline:none;
  border-color:var(--gold);
  background:var(--surface);
  box-shadow:0 0 0 4px var(--gold-soft);
}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{
  border-color:var(--mindx-red);
  box-shadow:0 0 0 4px var(--mindx-red-soft);
}
.field textarea{resize:vertical;min-height:96px}

.team-picker{
  display:flex;flex-direction:column;gap:var(--sp-2);
}
.field .team-chip,
.team-chip{
  display:flex;
  align-items:center;
  gap:var(--sp-3);
  padding:.85rem 1rem;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  cursor:pointer;
  transition:all var(--transition);
  font-size:var(--t-sm);
  color:var(--ink);
  line-height:1.2;
  min-height:52px;
  margin-bottom:0;
  font-weight:400;
  letter-spacing:0;
  text-transform:none;
}
.team-chip > span{
  flex:1;
  display:flex;align-items:center;
}
.team-chip:hover{border-color:var(--ink);background:var(--surface)}
.team-chip input{
  appearance:none;-webkit-appearance:none;
  width:20px;height:20px;
  border:1.5px solid var(--border);
  border-radius:4px;
  flex-shrink:0;
  transition:all var(--transition);
  position:relative;
  margin:0;
  align-self:center;
}
.team-chip input:checked{
  background:var(--gold);
  border-color:var(--gold);
}
.team-chip input:checked::after{
  content:"";
  position:absolute;top:3px;left:7px;
  width:5px;height:9px;
  border:solid #fff;
  border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.team-chip:has(input:checked){
  border-color:var(--gold);
  background:var(--gold-soft);
}

.form-privacy{
  font-size:var(--t-xs);
  color:var(--ink-faint);
  line-height:1.5;
  margin-top:var(--sp-4);
  text-align:center;
}
.form-privacy strong{color:var(--ink-muted)}

.form-status{
  margin-top:var(--sp-4);
  padding:0;
  font-size:var(--t-sm);
  min-height:0;
  transition:all var(--transition);
}
.form-status.is-error{
  padding:var(--sp-3) var(--sp-4);
  border-radius:var(--r-md);
  background:var(--mindx-red-soft);
  color:var(--mindx-red);
  border:1px solid color-mix(in oklab, var(--mindx-red) 25%, transparent);
}
.form-status.is-success{
  padding:var(--sp-3) var(--sp-4);
  border-radius:var(--r-md);
  background:var(--gold-soft);
  color:var(--gold);
  border:1px solid color-mix(in oklab, var(--gold) 30%, transparent);
}

@media (max-width: 860px){
  .register-grid{grid-template-columns:1fr}
}

/* ---------- FOOTER ---------- */
.site-footer{
  padding:clamp(var(--sp-12), 8vw, var(--sp-16)) 0 var(--sp-8);
  background:var(--ink-strong);
  color:color-mix(in oklab, var(--bg) 90%, transparent);
}
[data-theme="dark"] .site-footer{
  background:#050503;
}
.footer-inner{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1.2fr);
  gap:var(--sp-8);
  align-items:end;
}
.footer-brand{display:flex;align-items:center;gap:var(--sp-5);flex-wrap:wrap}
.footer-logo{
  height:32px;width:auto;
  filter:brightness(0) invert(1) sepia(1) saturate(0.15) brightness(1.05);
}
.footer-logo--light{display:none}
.footer-logo--dark{display:block}
.footer-tag{
  font-family:var(--font-serif);
  font-size:var(--t-sm);
  color:color-mix(in oklab, var(--bg) 70%, transparent);
  border-left:1px solid rgba(255,255,255,.16);
  padding-left:var(--sp-5);
}
.footer-meta{text-align:right}
.footer-line{margin-bottom:var(--sp-3)}
.footer-line--small{font-size:var(--t-xs);color:color-mix(in oklab, var(--bg) 55%, transparent);max-width:60ch;margin-left:auto}
.footer-label{
  font-size:var(--t-xs);
  letter-spacing:.24em;
  text-transform:uppercase;
  color:color-mix(in oklab, var(--bg) 50%, transparent);
  margin-right:var(--sp-3);
}
.footer-line a{
  color:var(--gold);
  border-bottom:1px solid transparent;
}
.footer-line a:hover{border-color:var(--gold)}
@media (max-width: 720px){
  .footer-inner{grid-template-columns:1fr}
  .footer-meta{text-align:left}
  .footer-line--small{margin-left:0}
}

/* ---------- MOBILE STICKY CTA ---------- */
.mobile-cta{
  display:none;
  position:fixed;left:var(--sp-4);right:var(--sp-4);bottom:var(--sp-4);
  z-index:60;
  background:var(--ink-strong);
  color:var(--bg);
  padding:.95rem 1.25rem;
  border-radius:999px;
  font-size:var(--t-sm);
  font-weight:500;
  text-align:center;
  box-shadow:var(--shadow-lg);
  letter-spacing:.02em;
}
.mobile-cta:hover{background:var(--gold)}

/* ---------- MODAL ---------- */
.modal{
  position:fixed;inset:0;z-index:90;
  display:flex;align-items:center;justify-content:center;
  padding:var(--sp-4);
}
.modal[hidden]{display:none}
.modal-backdrop{
  position:absolute;inset:0;
  background:rgba(15,13,10,.6);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  animation:fadeIn .32s ease-out;
}
.modal-panel{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  padding:clamp(var(--sp-6), 4vw, var(--sp-10));
  max-width:520px;width:100%;
  box-shadow:var(--shadow-lg);
  animation:panelIn .5s cubic-bezier(.16,1,.3,1);
  max-height:90vh;
  overflow:auto;
}
.modal-close{
  position:absolute;top:var(--sp-4);right:var(--sp-4);
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink-muted);
  border-radius:var(--r-md);
}
.modal-close:hover{background:var(--surface-2);color:var(--ink-strong)}
.modal-icon{
  width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  background:var(--gold-soft);
  color:var(--gold);
  margin-bottom:var(--sp-5);
}
.modal-panel h3{
  font-family:var(--font-serif);
  font-size:var(--t-xl);
  font-weight:500;
  color:var(--ink-strong);
  margin-bottom:var(--sp-3);
  letter-spacing:-.01em;
}
.modal-panel p{
  font-size:var(--t-base);
  color:var(--ink-muted);
  line-height:1.55;
  margin-bottom:var(--sp-3);
}
.modal-panel p strong{color:var(--ink-strong);font-weight:600}
.modal-panel em{color:var(--gold);font-style:normal;font-weight:600}
.modal-note{font-size:var(--t-sm)!important;color:var(--ink-faint)!important;margin-top:var(--sp-4)!important}
.modal-fallback{
  margin-top:var(--sp-3);margin-bottom:var(--sp-5);
  border:1px solid var(--border);border-radius:var(--r-md);
  padding:var(--sp-3);background:var(--bg);
}
.modal-fallback summary{
  cursor:pointer;font-size:var(--t-sm);color:var(--ink);
  padding:var(--sp-1) 0;font-weight:500;
}
.modal-fallback pre{
  font-family:'SF Mono', ui-monospace, monospace;
  font-size:12px;
  color:var(--ink);
  background:var(--surface-2);
  padding:var(--sp-3);
  border-radius:var(--r-sm);
  margin:var(--sp-3) 0;
  white-space:pre-wrap;word-break:break-word;
  max-height:200px;overflow:auto;
}
.modal-actions{
  display:flex;justify-content:flex-end;gap:var(--sp-3);
  margin-top:var(--sp-5);
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes panelIn{
  from{opacity:0;transform:translateY(16px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

/* ---------- REVEAL ANIMATIONS ---------- */
.reveal{
  opacity:0;transform:translateY(24px);
  transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1);
}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* ---------- MOBILE RESPONSIVE HEADER ---------- */
@media (max-width: 900px){
  .site-nav{
    position:fixed;top:0;right:-100%;
    width:min(85vw, 340px);height:100dvh;
    background:var(--surface);
    flex-direction:column;
    align-items:flex-start;
    padding:var(--sp-20) var(--sp-8) var(--sp-8);
    gap:var(--sp-5);
    box-shadow:var(--shadow-lg);
    transition:right var(--transition-slow);
    z-index:70;
  }
  .site-nav.is-open{right:0}
  .site-nav a{font-size:var(--t-lg);font-family:var(--font-serif);color:var(--ink-strong)}
  .header-actions .btn--sm{display:none}
  .menu-toggle{display:flex}
  .mobile-cta{display:block}
}

/* Extra polish */
.hero-title, .section-title, .team-name-en, .footer-tag{
  font-feature-settings:"ss01","liga","dlig","case";
}
