@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Space+Mono:wght@400;700&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --navy:   #02040F;
  --navy2:  #060919;
  --purple: #7C3AED;
  --purple2:#A855F7;
  --mint:   #00FFD1;
  --mint2:  #5EEAD4;
  --cyan:   #22D3EE;
  --white:  #FFFFFF;
  --gray:   #94A3B8;
  --gray2:  #475569;
  --glass:  rgba(255,255,255,0.03);
  --glass-border: rgba(255,255,255,0.07);
  --glow-purple: rgba(124,58,237,0.45);
  --glow-mint: rgba(0,255,209,0.3);
  --glow-cyan: rgba(34,211,238,0.25);
  --ff: 'Outfit', sans-serif;
  --fm: 'Space Mono', monospace;
  --fi: 'Inter', sans-serif;
  --ease: cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}

body {
  font-family: var(--fi);
  background: var(--navy);
  color: var(--white);
  overflow-x: hidden;
}

/* ── CANVAS BG ── */
#bg-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* ── SCANLINES ── */
body::after {
  content:'';
  position:fixed;
  inset:0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.03) 2px,
    rgba(0,0,0,0.03) 4px
  );
  pointer-events:none;
  z-index:1;
}

/* ── NAV ── */
nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.2rem 5%;
  transition: all .4s var(--ease);
}
nav.scrolled {
  background: rgba(2,4,15,.82);
  backdrop-filter: blur(20px) saturate(1.5);
  border-bottom: 1px solid rgba(0,255,209,.08);
  box-shadow: 0 0 40px rgba(0,255,209,.04);
}
.nav-logo {
  font-family: var(--ff);
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: .06em;
  background: linear-gradient(90deg, var(--white), var(--mint));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
}
.nav-logo::after {
  content: attr(data-text);
  position: absolute;
  left: 0; top: 0;
  background: linear-gradient(90deg, var(--white), var(--mint));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: blur(8px);
  opacity: .4;
}
.nav-links { display:flex; gap:2.5rem; list-style:none; }
.nav-links a {
  color: var(--gray);
  text-decoration: none;
  font-size: .85rem;
  font-weight: 500;
  letter-spacing: .04em;
  font-family: var(--fm);
  transition: color .3s;
  position: relative;
}
.nav-links a::after {
  content:'';
  position:absolute;
  bottom:-3px; left:0;
  width:0; height:1px;
  background: var(--mint);
  transition: width .3s var(--ease);
  box-shadow: 0 0 6px var(--mint);
}
.nav-links a:hover { color: var(--mint); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
  padding: .55rem 1.5rem;
  border-radius: 6px;
  background: transparent;
  border: 1px solid var(--mint);
  font-family: var(--fm);
  font-size: .78rem;
  color: var(--mint);
  cursor: pointer;
  letter-spacing: .08em;
  transition: all .3s var(--ease);
  position: relative;
  overflow: hidden;
}
.nav-cta::before {
  content:'';
  position:absolute;
  inset:0;
  background: var(--mint);
  transform: translateX(-100%);
  transition: transform .3s var(--ease);
}
.nav-cta:hover { color: var(--navy); box-shadow: 0 0 20px var(--glow-mint); }
.nav-cta:hover::before { transform: translateX(0); }
.nav-cta span { position: relative; z-index: 1; }

/* ── HERO ── */
#hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 8rem 5% 6rem;
  z-index: 2;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .4rem 1.2rem;
  border: 1px solid rgba(0,255,209,.25);
  background: rgba(0,255,209,.05);
  border-radius: 4px;
  font-family: var(--fm);
  font-size: .72rem;
  letter-spacing: .15em;
  color: var(--mint);
  margin-bottom: 2rem;
  animation: fadeUp .8s both;
}
.hero-badge .pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--mint);
  box-shadow: 0 0 10px var(--mint), 0 0 20px var(--mint);
  animation: blink 1.6s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.2} }

.hero-title {
  font-family: var(--ff);
  font-size: clamp(4rem, 10vw, 9rem);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -.03em;
  animation: fadeUp .9s .1s both;
  position: relative;
}
.hero-title .line1 {
  display: block;
  background: linear-gradient(135deg, #fff 0%, var(--purple2) 40%, var(--mint) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 40px rgba(124,58,237,.5));
}
.hero-title .line2 {
  display: block;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,.25);
  font-size: .65em;
  letter-spacing: .08em;
  margin-top: .1em;
}
.glitch {
  position: relative;
}
.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #fff 0%, var(--purple2) 40%, var(--mint) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.glitch::before {
  left: 2px;
  background: linear-gradient(135deg, var(--cyan), var(--purple2));
  -webkit-background-clip: text;
  background-clip: text;
  animation: glitch1 4s infinite;
  clip-path: polygon(0 0,100% 0,100% 35%,0 35%);
}
.glitch::after {
  left: -2px;
  background: linear-gradient(135deg, var(--mint), var(--purple));
  -webkit-background-clip: text;
  background-clip: text;
  animation: glitch2 4s infinite;
  clip-path: polygon(0 65%,100% 65%,100% 100%,0 100%);
}
@keyframes glitch1 {
  0%,94%,100%{transform:none;opacity:0}
  95%{transform:translateX(-2px) skewX(-5deg);opacity:.8}
  97%{transform:translateX(2px) skewX(3deg);opacity:.6}
}
@keyframes glitch2 {
  0%,94%,100%{transform:none;opacity:0}
  95%{transform:translateX(3px) skewX(4deg);opacity:.7}
  97%{transform:translateX(-1px) skewX(-2deg);opacity:.5}
}

.hero-sub {
  font-size: clamp(.95rem, 1.8vw, 1.2rem);
  color: var(--gray);
  max-width: 600px;
  margin: 1.8rem auto 0;
  line-height: 1.75;
  animation: fadeUp 1s .22s both;
}

.hero-tags {
  display: flex; flex-wrap: wrap; gap: .6rem;
  justify-content: center;
  margin-top: 2rem;
  animation: fadeUp 1s .32s both;
}
.hero-tag {
  padding: .3rem .9rem;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  border-radius: 3px;
  font-family: var(--fm);
  font-size: .72rem;
  letter-spacing: .08em;
  color: var(--gray2);
  transition: all .3s;
}
.hero-tag:hover {
  border-color: rgba(0,255,209,.3);
  color: var(--mint);
  background: rgba(0,255,209,.05);
}

.hero-btns {
  display: flex; gap: 1rem; flex-wrap: wrap;
  justify-content: center;
  margin-top: 3rem;
  animation: fadeUp 1s .42s both;
}
.btn-primary {
  padding: .9rem 2.4rem;
  background: linear-gradient(135deg, var(--purple), #5B21B6);
  border: none;
  border-radius: 6px;
  font-family: var(--fm);
  font-size: .82rem;
  letter-spacing: .1em;
  color: #fff;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: transform .3s, box-shadow .3s;
  box-shadow: 0 0 30px var(--glow-purple), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary::after {
  content:'';
  position:absolute;
  top:-50%; left:-50%;
  width:200%; height:200%;
  background: conic-gradient(transparent 0deg, rgba(255,255,255,.08) 90deg, transparent 120deg);
  animation: rotateSweep 3s linear infinite;
}
@keyframes rotateSweep { to { transform: rotate(360deg); } }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 0 50px var(--glow-purple); }

.btn-outline {
  padding: .9rem 2.4rem;
  background: transparent;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 6px;
  font-family: var(--fm);
  font-size: .82rem;
  letter-spacing: .1em;
  color: var(--white);
  cursor: pointer;
  transition: all .3s;
}
.btn-outline:hover {
  border-color: var(--mint);
  color: var(--mint);
  box-shadow: 0 0 20px var(--glow-mint);
}

.hero-scroll {
  position: absolute;
  bottom: 2.5rem; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-family: var(--fm);
  font-size: .65rem; letter-spacing: .15em;
  color: var(--gray2);
  animation: fadeUp 1s .8s both;
}
.scroll-bar {
  width: 1px; height: 50px;
  background: linear-gradient(to bottom, var(--mint), transparent);
  animation: scrollDrop 2s ease-in-out infinite;
}
@keyframes scrollDrop { 0%{transform:scaleY(0);transform-origin:top} 50%{transform:scaleY(1);transform-origin:top} 51%{transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

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

/* ── STATS ── */
#stats { position:relative; z-index:2; }
.stats-strip {
  border-top: 1px solid rgba(0,255,209,.07);
  border-bottom: 1px solid rgba(0,255,209,.07);
  background: rgba(0,255,209,.02);
  backdrop-filter: blur(10px);
}
.stats-grid {
  max-width: 1200px; margin: 0 auto;
  padding: 3rem 5%;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
}
.stat-item {
  text-align: center;
  padding: 1.5rem;
  position: relative;
}
.stat-item:not(:last-child)::after {
  content:'';
  position:absolute;
  right:0; top:25%; height:50%;
  width:1px;
  background: linear-gradient(to bottom, transparent, rgba(0,255,209,.2), transparent);
}
.stat-num {
  font-family: var(--ff);
  font-size: 2.8rem; font-weight: 900;
  background: linear-gradient(135deg, var(--white), var(--mint));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 15px rgba(0,255,209,.3));
}
.stat-label {
  font-family: var(--fm);
  color: var(--gray2);
  font-size: .72rem;
  letter-spacing: .1em;
  margin-top: .4rem;
}

/* ── SHARED SECTION ── */
section { position: relative; z-index: 2; }
.section-inner { max-width: 1200px; margin: 0 auto; padding: 8rem 5%; }

.section-label {
  font-family: var(--fm);
  font-size: .68rem;
  letter-spacing: .2em;
  color: var(--mint);
  display: flex; align-items: center; gap: .8rem;
  margin-bottom: 1.2rem;
}
.section-label::before {
  content:'';
  width:30px; height:1px;
  background: linear-gradient(to right, var(--mint), transparent);
  box-shadow: 0 0 6px var(--mint);
}

.section-title {
  font-family: var(--ff);
  font-size: clamp(2.2rem, 4.5vw, 3.5rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -.02em;
}
.section-title .accent {
  background: linear-gradient(135deg, var(--purple2), var(--mint));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.section-desc {
  color: var(--gray);
  font-size: .95rem;
  line-height: 1.8;
  max-width: 520px;
  margin-top: 1rem;
}

/* ── SCROLL REVEAL ── */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.reveal.visible { opacity:1; transform:none; }
.reveal-left { opacity:0; transform:translateX(-30px); transition: opacity .8s var(--ease),transform .8s var(--ease); }
.reveal-left.visible { opacity:1; transform:none; }
.reveal-right { opacity:0; transform:translateX(30px); transition: opacity .8s var(--ease),transform .8s var(--ease); }
.reveal-right.visible { opacity:1; transform:none; }

/* ── 3D GLASS CARDS ── */
.glass-card {
  background: rgba(255,255,255,.022);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  backdrop-filter: blur(12px);
  transition: border-color .4s, box-shadow .4s, transform .1s;
  transform-style: preserve-3d;
  will-change: transform;
}
.glass-card:hover {
  border-color: rgba(0,255,209,.18);
  box-shadow: 0 20px 60px rgba(0,0,0,.4), 0 0 40px rgba(0,255,209,.06);
}

/* ── VISION / MISSION ── */
#vision .section-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.vm-card {
  padding: 2.8rem;
  border-radius: 16px;
}
.vm-card .icon-box {
  width: 54px; height: 54px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  margin-bottom: 1.5rem;
  position: relative;
}
.vm-card .icon-box.p {
  background: linear-gradient(135deg, rgba(124,58,237,.25), rgba(168,85,247,.1));
  border: 1px solid rgba(124,58,237,.3);
  box-shadow: 0 0 20px rgba(124,58,237,.2);
}
.vm-card .icon-box.m {
  background: linear-gradient(135deg, rgba(0,255,209,.15), rgba(34,211,238,.08));
  border: 1px solid rgba(0,255,209,.25);
  box-shadow: 0 0 20px rgba(0,255,209,.15);
}
.vm-card h3 {
  font-family: var(--ff);
  font-size: 1.5rem; font-weight: 700; margin-bottom: .8rem;
}
.vm-card p { color: var(--gray); font-size: .93rem; line-height: 1.75; }
.vm-pills { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.5rem; }
.vm-pill {
  padding: .28rem .8rem;
  border-radius: 4px;
  font-family: var(--fm);
  font-size: .68rem; letter-spacing: .08em;
  border: 1px solid rgba(255,255,255,.08);
  color: var(--gray2);
  background: rgba(255,255,255,.03);
}

/* ── CORE VALUES ── */
#values {
  background: linear-gradient(180deg, transparent 0%, rgba(124,58,237,.04) 50%, transparent 100%);
}
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem;
  margin-top: 3.5rem;
}
.value-card {
  padding: 2.4rem;
  border-radius: 16px;
  position: relative;
  overflow: hidden;
  cursor: default;
}
.value-card .top-line {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  opacity: 0;
  transition: opacity .4s;
}
.value-card:hover .top-line { opacity: 1; }
.value-card:nth-child(1) .top-line { background: linear-gradient(90deg, var(--purple), var(--purple2)); box-shadow: 0 0 12px var(--purple); }
.value-card:nth-child(2) .top-line { background: linear-gradient(90deg, var(--mint), var(--cyan)); box-shadow: 0 0 12px var(--mint); }
.value-card:nth-child(3) .top-line { background: linear-gradient(90deg, var(--cyan), var(--purple2)); box-shadow: 0 0 12px var(--cyan); }

.value-card .corner {
  position: absolute;
  bottom: 1rem; right: 1rem;
  font-family: var(--fm);
  font-size: 4rem; font-weight: 700;
  opacity: .04;
  line-height: 1;
  pointer-events: none;
}
.value-num { font-family: var(--fm); font-size: .68rem; letter-spacing: .15em; color: var(--gray2); margin-bottom: .9rem; }
.value-card h3 { font-family: var(--ff); font-size: 1.2rem; font-weight: 700; margin-bottom: .6rem; }
.value-card p { color: var(--gray); font-size: .88rem; line-height: 1.7; }
.value-badge {
  display: inline-block;
  margin-top: 1.2rem;
  padding: .25rem .75rem;
  border-radius: 3px;
  font-family: var(--fm);
  font-size: .65rem; letter-spacing: .1em;
}
.vb-p { background: rgba(124,58,237,.15); border: 1px solid rgba(124,58,237,.3); color: var(--purple2); }
.vb-m { background: rgba(0,255,209,.08); border: 1px solid rgba(0,255,209,.25); color: var(--mint); }
.vb-c { background: rgba(34,211,238,.08); border: 1px solid rgba(34,211,238,.2); color: var(--cyan); }

/* ── BEHAVIOR ── */
#behavior .section-inner {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 5rem;
  align-items: center;
}
.behavior-list { display:flex; flex-direction:column; gap:1.2rem; margin-top:1rem; }
.behavior-item {
  display: flex; gap: 1.2rem;
  padding: 1.4rem;
  border-radius: 12px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  transition: border-color .35s, background .35s;
  backdrop-filter: blur(8px);
}
.behavior-item:hover {
  border-color: rgba(0,255,209,.18);
  background: rgba(0,255,209,.03);
}
.b-dot {
  width: 8px; height: 8px; border-radius: 50%;
  flex-shrink: 0; margin-top: 7px;
}
.b-dot.p { background: var(--purple2); box-shadow: 0 0 10px var(--purple2); }
.b-dot.m { background: var(--mint); box-shadow: 0 0 10px var(--mint); }
.b-dot.c { background: var(--cyan); box-shadow: 0 0 10px var(--cyan); }
.behavior-item h4 { font-family: var(--ff); font-weight: 700; margin-bottom: .3rem; }
.behavior-item p { color: var(--gray); font-size: .87rem; }

/* 3D HEX VISUAL */
.hex-visual {
  position: relative;
  height: 420px;
  border-radius: 20px;
  background: radial-gradient(ellipse at 50% 50%, rgba(0,255,209,.05) 0%, transparent 70%);
  border: 1px solid rgba(0,255,209,.07);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hex-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid;
}
.hex-ring-1 { width:320px; height:320px; border-color:rgba(0,255,209,.08); animation: spin 28s linear infinite; }
.hex-ring-2 { width:230px; height:230px; border-color:rgba(124,58,237,.12); animation: spin 18s linear infinite reverse; }
.hex-ring-3 { width:140px; height:140px; border-color:rgba(34,211,238,.1); animation: spin 10s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }
.ring-dot {
  position: absolute;
  width: 8px; height: 8px; border-radius: 50%;
  top: -4px; left: calc(50% - 4px);
}
.rd1 { background: var(--mint); box-shadow: 0 0 14px var(--mint); }
.rd2 { background: var(--purple2); box-shadow: 0 0 14px var(--purple2); }
.rd3 { background: var(--cyan); box-shadow: 0 0 14px var(--cyan); }

.lnc-core {
  position: relative; z-index: 2;
  width: 80px; height: 80px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--purple), #1E0654);
  border: 1px solid rgba(124,58,237,.4);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ff); font-weight: 900; font-size: .9rem;
  letter-spacing: .08em;
  box-shadow: 0 0 60px var(--glow-purple), 0 0 120px rgba(124,58,237,.15);
}
.hex-label {
  position: absolute;
  font-family: var(--fm);
  font-size: .68rem; letter-spacing: .08em;
  color: var(--gray2);
  padding: .3rem .8rem;
  background: rgba(2,4,15,.8);
  border: 1px solid var(--glass-border);
  border-radius: 4px;
  backdrop-filter: blur(8px);
}
.hl1 { top: 18%; right: 12%; }
.hl2 { bottom: 18%; left: 12%; }
.hl3 { top: 50%; right: 8%; transform: translateY(-50%); }
.hl4 { top: 50%; left: 8%; transform: translateY(-50%); }

/* ── PORTFOLIO ── */
#portfolio { }
.portfolio-grid {
  margin-top: 3.5rem;
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 1.2rem;
}
.p-main {
  padding: 3rem;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(0,255,209,.05), rgba(124,58,237,.06));
  border: 1px solid rgba(0,255,209,.12);
  position: relative; overflow: hidden;
  transition: transform .4s, border-color .4s;
}
.p-main:hover { border-color: rgba(0,255,209,.28); transform: translateY(-4px); }
.p-main::before {
  content:'';
  position:absolute;
  top:-100px; right:-100px;
  width:280px; height:280px;
  border-radius:50%;
  background: radial-gradient(ellipse, rgba(0,255,209,.07), transparent 70%);
  pointer-events:none;
}
.migo-icon {
  width: 78px; height: 78px;
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 1.8rem;
  box-shadow: 0 8px 32px rgba(0,255,209,.2), 0 0 0 1px rgba(0,255,209,.1);
}
.migo-icon img {
  width:100%; height:100%;
  object-fit:cover;
}
.migo-fallback {
  width:100%; height:100%;
  background: linear-gradient(135deg, #10D9C4, #7C3AED);
  display:flex; align-items:center; justify-content:center;
  font-family: var(--ff); font-weight:900; font-size:2rem;
}
.p-cat { font-family: var(--fm); font-size: .68rem; letter-spacing: .15em; color: var(--mint); margin-bottom: .7rem; }
.p-main h3 { font-family: var(--ff); font-size: 2.2rem; font-weight: 800; margin-bottom: .6rem; }
.p-main p { color: var(--gray); font-size: .93rem; line-height: 1.75; max-width: 380px; }
.migo-chips { display:flex; flex-wrap:wrap; gap:.5rem; margin-top: 1.5rem; }
.migo-chip {
  padding: .28rem .8rem;
  border-radius: 4px;
  font-family: var(--fm); font-size: .68rem; letter-spacing: .06em;
  border: 1px solid rgba(0,255,209,.18);
  background: rgba(0,255,209,.05);
  color: var(--mint2);
}
.p-side { display:flex; flex-direction:column; gap:1.2rem; }
.p-side-card {
  flex:1; padding: 2rem;
  border-radius: 16px;
  border: 1px solid var(--glass-border);
  background: var(--glass);
  backdrop-filter: blur(12px);
  transition: all .35s;
}
.p-side-card:hover { border-color: rgba(124,58,237,.25); background: rgba(124,58,237,.03); transform: translateX(4px); }
.p-coming { font-family: var(--fm); font-size: .65rem; letter-spacing: .15em; color: var(--purple2); margin-bottom: .6rem; }
.p-side-card h4 { font-family: var(--ff); font-size: 1.05rem; font-weight: 700; margin-bottom: .4rem; }
.p-side-card p { color: var(--gray); font-size: .83rem; line-height: 1.6; }

/* ── BRAND COLORS ── */
#brand { }
.colors-row { display:flex; flex-wrap:wrap; gap:1rem; margin-top:3rem; }
.color-card {
  flex:1; min-width:150px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  transition: transform .35s, box-shadow .35s;
}
.color-card:hover { transform:translateY(-6px); box-shadow: 0 20px 40px rgba(0,0,0,.3); }
.color-swatch { height: 100px; }
.color-info { padding: 1rem; background: rgba(255,255,255,.025); }
.color-name { font-family: var(--ff); font-weight: 700; font-size: .9rem; }
.color-meaning { color: var(--gray); font-size: .78rem; margin-top: .15rem; }
.color-hex { font-family: var(--fm); font-size: .7rem; color: var(--gray2); margin-top: .5rem; letter-spacing: .08em; }

/* ── CTA ── */
#cta { padding: 6rem 5%; text-align: center; }
.cta-wrap {
  max-width: 860px; margin: 0 auto;
  padding: 5rem 3rem;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(124,58,237,.12), rgba(0,255,209,.07));
  border: 1px solid rgba(124,58,237,.18);
  position: relative; overflow: hidden;
}
.cta-wrap::before {
  content:'';
  position:absolute;
  top:-120px; left:50%; transform:translateX(-50%);
  width:500px; height:300px;
  border-radius:50%;
  background: radial-gradient(ellipse, rgba(124,58,237,.2), transparent 70%);
}
.cta-wrap::after {
  content:'';
  position:absolute;
  bottom:-80px; right:-80px;
  width:200px; height:200px;
  border-radius:50%;
  background: radial-gradient(ellipse, rgba(0,255,209,.12), transparent 70%);
}
.cta-wrap h2 {
  font-family: var(--ff);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 800; line-height: 1.15;
  margin-bottom: 1rem; position: relative;
}
.cta-wrap p { color: var(--gray); font-size: 1rem; margin-bottom: 2.5rem; position: relative; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; position:relative; }

/* ── FOOTER ── */
footer {
  border-top: 1px solid var(--glass-border);
  padding: 3rem 5%;
  position: relative; z-index: 2;
}
.footer-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1.5rem;
}
.footer-logo {
  font-family: var(--ff); font-size: 1.2rem; font-weight: 900;
  background: linear-gradient(90deg, var(--white), var(--mint));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.footer-sub { color: var(--gray2); font-family: var(--fm); font-size: .72rem; letter-spacing: .06em; margin-top: .3rem; }
.footer-links { display:flex; gap:2rem; }
.footer-links a { color: var(--gray2); text-decoration: none; font-family: var(--fm); font-size: .75rem; letter-spacing: .06em; transition: color .3s; }
.footer-links a:hover { color: var(--mint); }
.footer-bottom {
  max-width: 1200px; margin: 1.5rem auto 0;
  padding-top: 1.5rem; border-top: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}
.footer-bottom p { color: var(--gray2); font-family: var(--fm); font-size: .72rem; letter-spacing: .04em; }

/* ── RESPONSIVE ── */
@media(max-width:960px){
  #vision .section-inner { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  #behavior .section-inner { grid-template-columns:1fr; }
  .hex-visual { height:280px; }
  .portfolio-grid { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .nav-links { display:none; }
}
@media(max-width:600px){
  .section-inner { padding:5rem 5%; }
  .hero-title { font-size:clamp(3rem,14vw,5rem); }
}
