    /* ════════════════════════════
       TOKENS
    ════════════════════════════ */
    :root {
      --black:   #111111;
      --white:   #ffffff;
      --off:     #f7f6f4;
      --gray-1:  #f0efed;
      --gray-2:  #dedad4;
      --gray-3:  #9e9a93;
      --gray-4:  #5a5650;
      --pink:    #d9607a;
      --pink-mid: rgba(217,96,122,.3);
      --pink-bg: #fdf0f2;
      --r: cubic-bezier(.16,1,.3,1);
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'DM Sans', system-ui, sans-serif;
      background: var(--white);
      color: var(--black);
      -webkit-font-smoothing: antialiased;
    }
    img { max-width: 100%; display: block; }
    a { text-decoration: none; color: inherit; }
    p { margin: 0; }

    /* ════════════════════════════
       LAYOUT
    ════════════════════════════ */
    .container {
      max-width: 1100px;
      margin: 0 auto;
      padding: 0 40px;
    }
    .section { padding: 96px 0; }
    .section--alt { background: var(--off); }

    /* ════════════════════════════
       NAV
    ════════════════════════════ */
    .nav {
      position: fixed; top: 0; left: 0; right: 0;
      z-index: 100;
      transition: background .3s, backdrop-filter .3s, box-shadow .3s;
    }
    .nav.scrolled {
      background: rgba(255,255,255,.9);
      backdrop-filter: blur(12px);
      box-shadow: 0 1px 0 var(--gray-1);
    }
    .nav__inner {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 40px;
      height: 56px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      align-items: center;
    }
    .nav__greeting {
      font-size: 12px;
      font-weight: 300;
      color: var(--gray-3);
      letter-spacing: .01em;
    }
    .nav__logo {
      font-family: 'DM Serif Display', serif;
      font-size: 16px;
      letter-spacing: -.02em;
      text-align: center;
      color: var(--black);
    }
    .nav__right {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 24px;
    }
    .nav__links {
      display: flex;
      gap: 24px;
      list-style: none;
    }
    .nav__links a {
      font-size: 13px;
      font-weight: 400;
      color: var(--gray-3);
      transition: color .2s;
    }
    .nav__links a:hover { color: var(--black); }
    .nav__icons {
      display: flex;
      gap: 12px;
      align-items: center;
    }
    .nav__icon-link {
      width: 32px; height: 32px;
      border-radius: 50%;
      border: 1px solid var(--gray-2);
      display: flex; align-items: center; justify-content: center;
      color: var(--gray-3);
      transition: border-color .2s, color .2s, background .2s;
    }
    .nav__icon-link:hover {
      border-color: var(--black);
      color: var(--black);
      background: var(--black);
      color: white;
    }
    /* Language selector */
    .nav__lang {
      position: relative;
      cursor: pointer;
    }
    .nav__lang-current {
      font-size: 11px;
      font-weight: 600;
      letter-spacing: .1em;
      color: var(--gray-3);
      padding: 4px 10px;
      border: 1px solid var(--gray-2);
      border-radius: 100px;
      transition: color .2s, border-color .2s;
      user-select: none;
      display: flex;
      align-items: center;
      gap: 6px;
    }
    .nav__lang:hover .nav__lang-current { color: var(--black); border-color: var(--gray-3); }
    .nav__lang-dropdown {
      position: absolute;
      top: calc(100% + 8px);
      right: 0;
      background: var(--white);
      border: 1px solid var(--gray-1);
      border-radius: 10px;
      box-shadow: 0 8px 24px rgba(0,0,0,.08);
      padding: 6px;
      display: flex;
      flex-direction: column;
      gap: 2px;
      opacity: 0;
      pointer-events: none;
      transform: translateY(-4px);
      transition: opacity .2s, transform .2s;
      min-width: 80px;
    }
    .nav__lang.open .nav__lang-dropdown {
      opacity: 1;
      pointer-events: all;
      transform: translateY(0);
    }
    .nav__lang-option {
      font-size: 11px;
      font-weight: 600;
      letter-spacing: .08em;
      color: var(--gray-3);
      background: none;
      border: none;
      cursor: pointer;
      padding: 6px 10px;
      border-radius: 6px;
      text-align: left;
      transition: background .15s, color .15s;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .nav__lang-option:hover { background: var(--off); color: var(--black); }
    .nav__lang-option--active { color: var(--pink); font-weight: 700; }

    /* ════════════════════════════
       HERO
    ════════════════════════════ */
    .hero-wrap {
      background-image: radial-gradient(circle, #d0ccc6 1px, transparent 1px);
      background-size: 24px 24px;
    }
    .hero {
      padding: 160px 40px 80px;
      max-width: 800px;
      margin: 0 auto;
      text-align: center;
    }
    .hero__name {
      font-size: clamp(48px, 9vw, 100px);
      line-height: 1;
      letter-spacing: -.04em;
      margin-bottom: 16px;
    }
    .hero__role {
      font-size: 16px;
      font-weight: 500;
      color: var(--pink);
      margin-bottom: 20px;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      min-height: 24px;
    }
    .hero__role::before {
      content: '·';
      color: var(--pink);
      font-size: 20px;
    }
    #heroRole {
      display: inline-block;
      transition: opacity .35s ease, transform .35s ease;
    }
    #heroRole.fade-out {
      opacity: 0;
      transform: translateY(-6px);
    }
    #heroRole.fade-in {
      opacity: 1;
      transform: translateY(0);
    }
    .hero__sub {
      font-size: 16px;
      font-weight: 300;
      color: var(--gray-3);
      line-height: 1.75;
      max-width: 500px;
      margin: 0 auto 28px;
    }
    .label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--gray-3);
      display: block;
      margin-bottom: 16px;
    }
    .heading {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(32px, 4vw, 48px);
      line-height: 1.05;
      letter-spacing: -.025em;
      margin-bottom: 16px;
    }
    .heading em { font-style: italic; }


    .marquee-wrap {
      overflow: hidden;
      border-top: 1px solid var(--gray-1);
      border-bottom: 1px solid var(--gray-1);
      padding: 0;
    }
    .marquee {
      display: flex;
      width: max-content;
      animation: marquee 28s linear infinite;
    }
    .marquee:hover { animation-play-state: paused; }
    @keyframes marquee { from { transform: translateX(0) } to { transform: translateX(-50%) } }
    .marquee__group { display: flex; }
    .marquee__slide {
      width: 260px; height: 200px;
      flex-shrink: 0;
      border-right: 1px solid var(--gray-1);
      overflow: hidden;
      background: var(--gray-1);
    }
    .marquee__slide img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .6s var(--r);
    }
    .marquee__slide:hover img { transform: scale(1.04); }

    /* ════════════════════════════
       VALUE
    ════════════════════════════ */
    .value__grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 80px;
      align-items: start;
    }
    .value__right {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .value__card {
      background: var(--white);
      border-radius: 16px;
      padding: 20px;
    }
    .value__card-icon { font-size: 24px; margin-bottom: 10px; }
    .value__card-title {
      font-size: 13px;
      font-weight: 500;
      margin-bottom: 6px;
    }
    .value__card-text {
      font-size: 12px;
      font-weight: 300;
      color: var(--gray-3);
      line-height: 1.6;
    }

    /* ════════════════════════════
       PROJECTS
    ════════════════════════════ */
    .projects__grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }

    /* First card spans full width featured */
    /* ════ PROJECTS GRID ════ */
    .projects__grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }

    /* ════ BASE CARD ════ */
    .pcard {
      background: var(--white);
      border: 1px solid var(--gray-1);
      border-radius: 20px;
      overflow: hidden;
      cursor: pointer;
      display: flex;
      flex-direction: column;
      transition: transform .4s var(--r), box-shadow .4s var(--r);
      will-change: transform;
    }
    .pcard:hover {
      transform: translateY(-5px);
      box-shadow: 0 20px 48px rgba(0,0,0,.09);
    }

    /* ════ FEATURED CARD (full width, horizontal) ════ */
    .pcard--featured {
      grid-column: span 2;
      flex-direction: row;
      align-items: stretch;
    }
    .pcard--featured .pcard__thumb {
      order: 2;
      width: 36%;
      flex-shrink: 0;
      aspect-ratio: unset;
      min-height: 300px;
      border-radius: 0 20px 20px 0;
    }
    .pcard--featured .pcard__body {
      order: 1;
      flex: 1;
      padding: 40px 44px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 0;
    }
    .pcard--featured .pcard__title {
      font-size: clamp(20px, 2.2vw, 26px);
    }

    /* ════ THUMB ════ */
    .pcard__thumb {
      width: 100%;
      aspect-ratio: 16/9;
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
    .pcard__thumb-bg {
      position: absolute;
      inset: 0;
      transition: transform .6s var(--r);
    }
    .pcard:hover .pcard__thumb-bg { transform: scale(1.04); }

    .pcard:nth-child(1) .pcard__thumb-bg { background: linear-gradient(135deg, #e8d5f5 0%, #c9b8e8 100%); background-image: radial-gradient(circle, rgba(255,255,255,.5) 1px, transparent 1px), linear-gradient(135deg, #e8d5f5 0%, #c9b8e8 100%); background-size: 20px 20px, 100% 100%; }
    .pcard:nth-child(2) .pcard__thumb-bg { background: linear-gradient(135deg, #cce8f4 0%, #a8d4ea 100%); background-image: radial-gradient(circle, rgba(255,255,255,.5) 1px, transparent 1px), linear-gradient(135deg, #cce8f4 0%, #a8d4ea 100%); background-size: 20px 20px, 100% 100%; }
    .pcard:nth-child(3) .pcard__thumb-bg { background: linear-gradient(135deg, var(--pink-bg) 0%, #f7c5cf 100%); background-image: radial-gradient(circle, rgba(255,255,255,.5) 1px, transparent 1px), linear-gradient(135deg, var(--pink-bg) 0%, #f7c5cf 100%); background-size: 20px 20px, 100% 100%; }

    .pcard__thumb-label {
      position: relative;
      font-family: 'DM Serif Display', serif;
      font-size: clamp(20px, 2.8vw, 36px);
      letter-spacing: -.02em;
      color: rgba(0,0,0,.15);
      pointer-events: none;
      user-select: none;
      text-align: center;
      line-height: 1.2;
    }
    .pcard__year {
      position: absolute;
      top: 16px; left: 20px;
      font-size: 11px;
      font-weight: 500;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: rgba(0,0,0,.45);
      background: rgba(255,255,255,.65);
      backdrop-filter: blur(6px);
      padding: 4px 10px;
      border-radius: 100px;
    }
    .pcard__arrow {
      position: absolute;
      top: 16px; right: 20px;
      width: 32px; height: 32px;
      background: rgba(255,255,255,.9);
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 14px;
      color: var(--black);
      opacity: 0;
      transform: scale(.8);
      transition: opacity .3s var(--r), transform .3s var(--r);
    }
    .pcard:hover .pcard__arrow { opacity: 1; transform: scale(1); }

    /* ════ BODY ════ */
    .pcard__body {
      padding: 24px 28px 28px;
      flex: 1;
      display: flex;
      flex-direction: column;
    }
    .pcard__company {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: var(--pink);
      margin-bottom: 10px;
    }
    .pcard__tags {
      display: flex; gap: 6px; flex-wrap: wrap;
      margin-bottom: 14px;
    }
    .pcard__tag {
      font-size: 10px;
      font-weight: 500;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--gray-3);
      padding: 3px 10px;
      border: 1px solid var(--gray-2);
      border-radius: 100px;
    }
    .pcard__title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(16px, 1.8vw, 20px);
      line-height: 1.25;
      letter-spacing: -.015em;
      margin-bottom: 10px;
      flex: 1;
      color: var(--black);
    }
    .pcard__summary {
      font-size: 13px;
      font-weight: 300;
      color: var(--gray-3);
      line-height: 1.65;
      margin-bottom: 20px;
    }
    .pcard__footer {
      display: flex;
      align-items: center;
      justify-content: space-between;
      border-top: 1px solid var(--gray-1);
      padding-top: 16px;
      margin-top: auto;
    }
    .pcard__cta {
      font-size: 13px;
      font-weight: 500;
      color: var(--gray-3);
      display: flex;
      align-items: center;
      gap: 8px;
      transition: color .25s;
    }
    .pcard:hover .pcard__cta { color: var(--pink); }
    .pcard__cta-arrow {
      width: 26px; height: 26px;
      border-radius: 50%;
      border: 1px solid currentColor;
      display: flex; align-items: center; justify-content: center;
      font-size: 12px;
      transition: background .25s, color .25s, border-color .25s;
    }
    .pcard:hover .pcard__cta-arrow {
      background: var(--pink);
      border-color: var(--pink);
      color: white;
    }

    /* ════ RESPONSIVE ════ */
    @media (max-width: 700px) {
      .projects__grid { grid-template-columns: 1fr; }
      .pcard--featured { grid-column: span 1; flex-direction: column; }
      .pcard--featured .pcard__thumb { width: 100%; min-height: 200px; border-radius: 20px 20px 0 0; order: 1; }
      .pcard--featured .pcard__body { order: 2; padding: 24px 28px 28px; justify-content: flex-start; }
      .pcard__thumb { aspect-ratio: 16/9; }
    }


    /* ════════════════════════════
       MODAL
    ════════════════════════════ */
    .modal-overlay {
      position: fixed; inset: 0;
      background: rgba(0,0,0,.5);
      backdrop-filter: blur(4px);
      z-index: 200;
      display: flex;
      align-items: flex-end;
      justify-content: center;
      opacity: 0;
      pointer-events: none;
      transition: opacity .35s var(--r);
    }
    .modal-overlay.active {
      opacity: 1;
      pointer-events: all;
    }
    .modal {
      background: var(--white);
      border-radius: 24px 24px 0 0;
      width: 100%;
      max-width: 860px;
      max-height: 92vh;
      display: flex;
      flex-direction: column;
      overflow: hidden;
      transform: translateY(40px);
      transition: transform .4s var(--r);
      position: relative;
    }
    .modal-overlay.active .modal { transform: translateY(0); }
    .modal__handle {
      width: 36px; height: 4px;
      background: var(--gray-2);
      border-radius: 2px;
      margin: 12px auto 0;
      flex-shrink: 0;
    }
    .modal__topbar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 12px 20px 12px;
      flex-shrink: 0;
    }
    .modal__nav { display: flex; align-items: center; gap: 10px; }
    .modal__nav-btn {
      width: 32px; height: 32px;
      border-radius: 50%;
      border: 1px solid var(--gray-2);
      background: none;
      cursor: pointer;
      font-size: 14px;
      display: flex; align-items: center; justify-content: center;
      transition: border-color .2s, background .2s;
    }
    .modal__nav-btn:hover { border-color: var(--black); background: var(--black); color: white; }
    .modal__counter {
      font-size: 12px;
      font-weight: 500;
      color: var(--gray-3);
      min-width: 36px;
      text-align: center;
    }
    .modal__close {
      width: 32px; height: 32px;
      border-radius: 50%;
      border: 1px solid var(--gray-2);
      background: none;
      cursor: pointer;
      font-size: 14px;
      display: flex; align-items: center; justify-content: center;
      transition: border-color .2s, background .2s;
    }
    .modal__close:hover { border-color: var(--black); background: var(--black); color: white; }
    .modal__body {
      overflow-y: auto;
      flex: 1;
    }
    .modal__case { display: none; }
    .modal__case.active { display: block; }

    /* Hero */
    .modal__case-hero {
      padding: 28px 40px 24px;
      border-bottom: 1px solid var(--gray-1);
    }
    .modal__case-tags {
      display: flex; gap: 6px; flex-wrap: wrap;
      margin-bottom: 14px;
    }
    .project__tag {
      font-size: 10px;
      font-weight: 500;
      letter-spacing: .09em;
      text-transform: uppercase;
      color: var(--gray-3);
      padding: 3px 10px;
      border: 1px solid var(--gray-2);
      border-radius: 100px;
    }
    .project__tag--pink {
      background: var(--pink-bg);
      border-color: var(--pink-mid);
      color: var(--pink);
    }
    .modal__case-title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(22px, 3vw, 32px);
      line-height: 1.15;
      letter-spacing: -.02em;
      margin-bottom: 12px;
    }
    .modal__case-summary {
      font-size: 14px;
      font-weight: 300;
      color: var(--gray-3);
      line-height: 1.75;
      max-width: 620px;
    }

    /* Meta strip */
    .modal__case-meta {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      border-bottom: 1px solid var(--gray-1);
    }
    .modal__case-meta-item {
      padding: 16px 40px;
      border-right: 1px solid var(--gray-1);
    }
    .modal__case-meta-item:last-child { border-right: none; }
    .modal__case-meta-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: var(--gray-3);
      margin-bottom: 4px;
    }
    .modal__case-meta-value {
      font-size: 14px;
      font-weight: 500;
    }

    /* Impact block */
    .modal__case-impact {
      padding: 32px 40px;
      background: var(--black);
    }
    .modal__case-impact-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--pink);
      display: flex;
      align-items: center;
      gap: 8px;
      margin-bottom: 12px;
    }
    .modal__case-impact-label::before {
      content: '';
      display: inline-block;
      width: 20px; height: 1.5px;
      background: var(--pink);
    }
    .modal__case-impact-text {
      font-size: 15px;
      font-weight: 300;
      color: rgba(255,255,255,.8);
      line-height: 1.8;
      max-width: 600px;
    }
    .modal__case-impact-text strong { color: white; font-weight: 500; }

    /* ── Case visual blocks ── */
    .case-block {
      padding: 36px 40px;
      border-top: 1px solid var(--gray-1);
    }
    .case-block--tinted { background: var(--off); }
    .case-block__label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--pink);
      margin-bottom: 10px;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .case-block__label::before {
      content: '';
      display: inline-block;
      width: 20px; height: 1.5px;
      background: var(--pink);
      flex-shrink: 0;
    }
    .case-block__lead {
      font-size: 15px;
      font-weight: 300;
      color: var(--gray-4);
      line-height: 1.8;
      max-width: 640px;
    }
    .case-block__lead strong { font-weight: 500; color: var(--black); }
    .case-block__section-title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(19px, 2.2vw, 24px);
      line-height: 1.2;
      letter-spacing: -.02em;
      margin-bottom: 14px;
      color: var(--black);
    }

    /* Pain cards */
    .pain-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
      gap: 10px;
      margin-top: 16px;
    }
    .pain-card {
      padding: 16px;
      background: var(--white);
      border-radius: 12px;
      border-top: 2px solid var(--pink);
      transition: transform .25s var(--r), box-shadow .25s;
    }
    .pain-card:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.06); }
    .pain-card__cat {
      font-size: 10px; font-weight: 700;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--pink); margin-bottom: 6px;
    }
    .pain-card__text {
      font-size: 12px; font-weight: 300;
      color: var(--gray-4); line-height: 1.55;
    }

    /* Quote */
    .case-quote {
      margin-top: 20px;
      padding: 22px 24px;
      background: var(--white);
      border-radius: 12px;
      border-left: 3px solid var(--pink);
      position: relative;
    }
    .case-quote::before {
      content: '"';
      font-family: 'DM Serif Display', serif;
      font-size: 60px;
      color: var(--pink-bg);
      position: absolute;
      top: 8px; left: 16px;
      line-height: 1;
    }
    .case-quote__text {
      font-family: 'DM Serif Display', serif;
      font-style: italic;
      font-size: 14px;
      line-height: 1.7;
      color: var(--gray-4);
      margin-bottom: 10px;
      position: relative;
    }
    .case-quote__author {
      font-size: 11px; font-weight: 600;
      color: var(--gray-3);
      letter-spacing: .06em; text-transform: uppercase;
    }

    /* Timeline */
    .timeline { display: flex; flex-direction: column; gap: 0; }
    .timeline__item {
      display: grid;
      grid-template-columns: 36px 1fr;
      gap: 0;
      padding-bottom: 24px;
    }
    .timeline__item:last-child { padding-bottom: 0; }
    .timeline__spine {
      display: flex; flex-direction: column;
      align-items: center; padding-top: 4px;
    }
    .timeline__dot {
      width: 10px; height: 10px;
      border-radius: 50%;
      background: var(--pink);
      flex-shrink: 0;
      box-shadow: 0 0 0 3px var(--pink-bg);
    }
    .timeline__line {
      width: 1px; flex: 1;
      background: var(--gray-2); margin-top: 6px;
    }
    .timeline__item:last-child .timeline__line { display: none; }
    .timeline__step {
      font-size: 10px; font-weight: 700;
      letter-spacing: .12em; text-transform: uppercase;
      color: var(--pink); margin-bottom: 3px;
    }
    .timeline__title {
      font-family: 'DM Serif Display', serif;
      font-size: 17px; color: var(--black);
      margin-bottom: 7px; line-height: 1.2;
    }
    .timeline__text {
      font-size: 13px; font-weight: 300;
      color: var(--gray-4); line-height: 1.75;
    }

    /* Tool pills */
    .tool-pills { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
    .tool-pill {
      font-size: 11px; font-weight: 500;
      color: var(--gray-3); background: var(--gray-1);
      border-radius: 100px; padding: 4px 12px;
      border: 1px solid var(--gray-2);
    }

    /* Role items */
    .role-item {
      padding: 14px 16px; background: var(--off);
      border-radius: 10px; display: flex;
      gap: 12px; align-items: center;
      border: 1px solid transparent;
      transition: border-color .25s, background .25s;
    }
    .role-item:hover { border-color: var(--pink-mid); background: var(--pink-bg); }
    .role-item__num { color: var(--pink); font-size: 13px; font-weight: 700; flex-shrink: 0; width: 20px; }
    .role-item__text { font-size: 13px; font-weight: 400; color: var(--gray-4); line-height: 1.4; }

    /* Stat row */
    .stat-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
      margin: 20px 0;
    }
    .stat-card {
      background: var(--white);
      border-radius: 12px;
      padding: 20px 18px;
      text-align: center;
      border: 1px solid var(--gray-1);
      transition: border-color .25s, transform .3s var(--r);
    }
    .stat-card:hover { border-color: var(--pink); transform: translateY(-2px); }
    .stat-card__num {
      font-family: 'DM Serif Display', serif;
      font-size: 36px; color: var(--pink);
      line-height: 1; margin-bottom: 6px;
    }
    .stat-card__label { font-size: 12px; font-weight: 500; color: var(--black); margin-bottom: 4px; }
    .stat-card__sub { font-size: 11px; font-weight: 300; color: var(--gray-3); line-height: 1.5; }

    /* Priority items */
    .priority-item {
      padding: 16px 20px; background: var(--white);
      border-radius: 10px; display: flex;
      align-items: center; gap: 16px;
      border: 1px solid var(--gray-1);
      transition: border-color .25s, transform .25s var(--r);
    }
    .priority-item:hover { border-color: var(--pink); transform: translateX(3px); }
    .priority-item__num {
      font-family: 'DM Serif Display', serif;
      font-size: 28px; color: var(--pink);
      width: 32px; flex-shrink: 0; line-height: 1;
    }
    .priority-item__body { display: flex; flex-direction: column; gap: 2px; }
    .priority-item__title { font-size: 13px; font-weight: 600; color: var(--black); }
    .priority-item__sub { font-size: 12px; font-weight: 300; color: var(--gray-3); }

    /* Validation note */
    .validation-note {
      display: flex; gap: 14px; align-items: flex-start;
      padding: 18px 20px; background: var(--pink-bg);
      border-radius: 12px; margin-top: 16px;
      border: 1px solid var(--pink-mid);
    }
    .validation-note__icon {
      width: 28px; height: 28px;
      background: var(--pink); color: white;
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 12px; font-weight: 700; flex-shrink: 0;
    }

    /* Media placeholders */
    .media-placeholder { border-radius: 14px; overflow: hidden; margin: 20px 0; position: relative; }
    .media-placeholder--image {
      background: var(--gray-1); border: 2px dashed var(--gray-2);
      aspect-ratio: 16/9;
      display: flex; flex-direction: column;
      align-items: center; justify-content: center; gap: 8px;
      cursor: pointer;
      transition: border-color .25s, background .25s;
    }
    .media-placeholder--image:hover { border-color: var(--pink); background: var(--pink-bg); }
    .media-placeholder--video {
      background: #0f0f0f; aspect-ratio: 16/9;
      display: flex; flex-direction: column;
      align-items: center; justify-content: center; gap: 12px;
    }
    .media-placeholder__icon {
      width: 52px; height: 52px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center; font-size: 20px;
    }
    .media-placeholder--image .media-placeholder__icon { background: var(--gray-2); }
    .media-placeholder--video .media-placeholder__icon {
      background: rgba(217,96,122,.12); border: 1.5px solid rgba(217,96,122,.3);
    }
    .media-placeholder__label { font-size: 11px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
    .media-placeholder--image .media-placeholder__label { color: var(--gray-3); }
    .media-placeholder--video .media-placeholder__label { color: rgba(255,255,255,.45); }
    .media-placeholder__sub { font-size: 11px; font-weight: 300; }
    .media-placeholder--image .media-placeholder__sub { color: var(--gray-3); }
    .media-placeholder--video .media-placeholder__sub { color: rgba(255,255,255,.25); }

    @media (max-width: 640px) {
      .case-block { padding: 20px; }
      .pain-grid { grid-template-columns: 1fr 1fr; }
      .stat-row { grid-template-columns: 1fr; }
      .modal { border-radius: 16px 16px 0 0; max-height: 95vh; }
      .modal__case-meta { grid-template-columns: 1fr 1fr; }
      .modal__case-meta-item:nth-child(3) { grid-column: span 2; border-right: none; border-top: 1px solid var(--gray-1); }
      .modal__case-hero { padding: 24px 20px 20px; }
      .modal__case-impact { padding: 20px; }
    }

    /* ════════════════════════════
       ABOUT
    ════════════════════════════ */
    .about__grid {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 80px; align-items: start;
    }
    .about__text {
      font-size: 16px; font-weight: 300;
      color: var(--gray-4); line-height: 1.8; margin-bottom: 20px;
    }
    .about__text strong { font-weight: 500; color: var(--black); }
    .about__pillars { margin-top: 32px; }
    .about__pillar {
      display: grid; grid-template-columns: 48px 1fr;
      gap: 20px; padding: 20px 0;
      border-bottom: 1px solid var(--gray-1);
      align-items: start;
    }
    .about__pillar:first-child { border-top: 1px solid var(--gray-1); }
    .about__pillar-num {
      font-family: 'DM Serif Display', serif;
      font-size: 28px; color: var(--pink); line-height: 1;
    }
    .about__pillar-title { font-size: 14px; font-weight: 500; margin-bottom: 4px; }
    .about__pillar-text { font-size: 13px; font-weight: 300; color: var(--gray-3); line-height: 1.6; }
    .about__right {}
    .about__skills-title {
      font-size: 10px; font-weight: 700;
      letter-spacing: .16em; text-transform: uppercase;
      color: var(--gray-3); margin-bottom: 16px;
      display: flex; align-items: center; gap: 8px;
    }
    .about__skills-title::before { content: ''; display: inline-block; width: 20px; height: 1.5px; background: var(--gray-2); }
    .about__skills { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 40px; }
    .about__skill {
      font-size: 12px; font-weight: 400;
      padding: 6px 14px; border-radius: 100px;
      border: 1px solid var(--gray-2);
      color: var(--gray-4);
      transition: border-color .2s, color .2s;
    }
    .about__skill:hover { border-color: var(--pink); color: var(--pink); }
    .about__quote {
      font-family: 'DM Serif Display', serif;
      font-style: italic;
      font-size: 18px; line-height: 1.55;
      color: var(--gray-4);
      padding-left: 20px;
      border-left: 2px solid var(--pink);
    }

    /* ════════════════════════════
       PROOF / EXPERIENCE
    ════════════════════════════ */
    .proof__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
    .proof__exp-list { margin-top: 16px; }
    .proof__exp-item {
      display: grid; grid-template-columns: 20px 80px 1fr;
      gap: 16px; padding: 20px 0;
      border-bottom: 1px solid var(--gray-1);
      align-items: start;
    }
    .proof__exp-item:first-child { border-top: 1px solid var(--gray-1); }
    .proof__exp-dot {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--gray-2); margin-top: 5px;
      transition: background .25s;
    }
    .proof__exp-item:hover .proof__exp-dot { background: var(--pink); }
    .proof__exp-year { font-size: 11px; font-weight: 500; color: var(--gray-3); margin-top: 3px; }
    .proof__exp-role { font-size: 13px; font-weight: 500; margin-bottom: 3px; }
    .proof__exp-company { font-size: 12px; font-weight: 300; color: var(--gray-3); }
    .proof__stats {
      display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 16px;
    }
    .proof__stat {
      background: var(--off); border-radius: 16px;
      padding: 24px; text-align: center;
    }
    .proof__stat-num {
      font-family: 'DM Serif Display', serif;
      font-size: 40px; color: var(--black);
      line-height: 1; margin-bottom: 6px;
    }
    .proof__stat-num em { font-style: italic; color: var(--pink); }
    .proof__stat-label { font-size: 12px; font-weight: 300; color: var(--gray-3); line-height: 1.5; }

    /* ════════════════════════════
       CTA
    ════════════════════════════ */
    .cta-section { background: var(--black); }
    .cta__box {
      max-width: 700px; margin: 0 auto;
      padding: 96px 40px;
      text-align: center;
    }
    .cta__label { color: var(--pink); justify-content: center; margin-bottom: 20px; }
    .cta__title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(32px, 4vw, 48px);
      color: var(--white);
      line-height: 1.1; letter-spacing: -.02em;
      margin-bottom: 16px;
    }
    .cta__sub {
      font-size: 15px; font-weight: 300;
      color: rgba(255,255,255,.5);
      line-height: 1.75; margin-bottom: 36px;
    }
    .cta__btn {
      display: inline-flex; align-items: center; gap: 10px;
      background: var(--pink); color: white;
      font-size: 14px; font-weight: 500;
      padding: 14px 28px; border-radius: 100px;
      transition: opacity .2s, transform .2s var(--r);
    }
    .cta__btn:hover { opacity: .88; transform: translateY(-2px); }

    /* ════════════════════════════
       FOOTER
    ════════════════════════════ */
    .footer {
      border-top: 1px solid var(--gray-1);
      padding: 28px 40px;
      display: flex; align-items: center;
      justify-content: space-between;
    }
    .footer__copy { font-size: 12px; font-weight: 300; color: var(--gray-3); }
    .footer__links { display: flex; gap: 20px; }
    .footer__links a { font-size: 12px; color: var(--gray-3); transition: color .2s; }
    .footer__links a:hover { color: var(--black); }

    /* ════════════════════════════
       REVEAL
    ════════════════════════════ */
    .reveal {
      opacity: 0;
      transform: translateY(28px);
      transition: opacity .75s var(--r), transform .75s var(--r);
    }
    .reveal.visible { opacity: 1; transform: none; }
    /* Card specific hover lift */
    .pcard { will-change: transform; }

    @media (max-width: 900px) {
      .hero { grid-template-columns: 1fr; gap: 28px; }
      .value__grid { grid-template-columns: 1fr; gap: 40px; }
      .about__grid { grid-template-columns: 1fr; gap: 40px; }
      .proof__grid { grid-template-columns: 1fr; gap: 40px; }
      .proof__stats { grid-template-columns: 1fr 1fr; }
      .cta__box { padding: 48px 32px; }
      .section { padding: 72px 0; }
    }
    @media (max-width: 640px) {
      .container { padding: 0 20px; }
      .nav__inner { padding: 0 20px; grid-template-columns: 1fr auto; }
      .nav__greeting { display: none; }
      .nav__right { gap: 12px; }
      .nav__links { display: none; }
      .hero { padding: 120px 20px 56px; }
      .hero__name { font-size: clamp(44px, 12vw, 80px); }
      .value__right { grid-template-columns: 1fr; }
      .proof__stats { grid-template-columns: 1fr; }
      .marquee__slide { width: 180px; height: 180px; }
      .section { padding: 56px 0; }
    }
    /* ════════════════════════════
       SOBRE MIM
    ════════════════════════════ */
    .about-hero { padding: 20px 0 40px; }
    .about-hero__title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(32px, 4vw, 48px);
      letter-spacing: -.03em;
      line-height: 1.05;
      margin-bottom: 48px;
      color: var(--black);
    }
    .about-hero__grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 40px;
      align-items: start;
    }
    .about-hero__photo {
      border-radius: 16px;
      overflow: hidden;
      background: var(--gray-1);
      aspect-ratio: 1/1;
    }
    .about-hero__photo img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
    }
    .about-hero__subtitle {
      font-family: 'DM Serif Display', serif;
      font-size: 20px;
      letter-spacing: -.015em;
      margin-bottom: 20px;
      color: var(--black);
    }
    .about-hero__text p {
      font-size: 15px;
      font-weight: 300;
      color: var(--gray-4);
      line-height: 1.8;
      margin-bottom: 16px;
    }
    .about-hero__text p:last-child { margin-bottom: 0; }

    /* Interesses */
    .about-interests__title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(32px, 4vw, 48px);
      letter-spacing: -.03em;
      margin-bottom: 20px;
      color: var(--black);
    }
    .about-interests__text {
      font-size: 15px;
      font-weight: 300;
      color: var(--gray-4);
      line-height: 1.8;
      max-width: 860px;
      margin-bottom: 36px;
    }
    .about-gallery {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: 12px;
    }
    .about-gallery__item {
      border-radius: 12px;
      overflow: hidden;
      background: var(--gray-2);
      aspect-ratio: 3/4;
    }
    .about-gallery__item img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
      transition: transform .5s var(--r);
    }
    .about-gallery__item:hover img { transform: scale(1.04); }

    /* CTA override */
    .cta-section { background: var(--white); border-top: 1px solid var(--gray-1); }
    .cta__box {
      max-width: 860px;
      padding: 80px 40px;
    }
    .cta__title {
      font-family: 'DM Serif Display', serif;
      font-size: clamp(32px, 4vw, 48px);
      color: var(--black);
      line-height: 1.05;
      letter-spacing: -.03em;
      margin-bottom: 12px;
    }
    .cta__sub {
      font-size: 16px;
      font-weight: 300;
      color: var(--gray-3);
      line-height: 1.75;
      margin-bottom: 32px;
    }
    .cta__btn {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      background: var(--black);
      color: white;
      font-size: 14px;
      font-weight: 500;
      padding: 14px 28px;
      border-radius: 100px;
      transition: background .2s, transform .2s var(--r);
    }
    .cta__btn:hover { background: var(--pink); transform: translateY(-2px); }

    /* Responsive */
    @media (max-width: 900px) {
      .about-hero__grid { grid-template-columns: 1fr; gap: 32px; }
      .about-gallery { grid-template-columns: repeat(3, 1fr); }
    }
    @media (max-width: 640px) {
      .about-gallery { grid-template-columns: repeat(2, 1fr); }
      .cta__box { padding: 56px 20px; }
    }


    /* ════════════════════════════
       FOOTER
    ════════════════════════════ */
    .footer {
      border-top: 1px solid var(--gray-1);
      padding: 28px 40px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      max-width: 100%;
    }
    .footer__copy { font-size: 12px; font-weight: 300; color: var(--gray-3); }
    .footer__links { display: flex; gap: 20px; }
    .footer__links a { font-size: 12px; color: var(--gray-3); transition: color .2s; }
    .footer__links a:hover { color: var(--black); }

    /* Personas carousel */
    .personas-carousel { position: relative; border-radius: 14px; overflow: hidden; background: var(--gray-1); }
    .personas-carousel__track {
      display: flex;
      transition: transform .4s var(--r);
    }
    .personas-carousel__item {
      min-width: 100%;
      aspect-ratio: 16/9;
      background: var(--gray-1);
      display: flex; align-items: center; justify-content: center;
      position: relative;
    }
    .personas-carousel__item img {
      width: 100%; height: 100%; object-fit: cover; display: block;
    }
    .personas-carousel__item::after {
      content: '🖼️  Inserir imagem da persona';
      position: absolute;
      font-size: 11px; font-weight: 600;
      letter-spacing: .1em; text-transform: uppercase;
      color: var(--gray-3);
      display: flex; align-items: center; gap: 6px;
    }
    .personas-carousel__item img[src] ~ ::after { display: none; }
    .personas-carousel__controls {
      display: flex; align-items: center; justify-content: center;
      gap: 12px; padding: 12px;
      background: var(--white); border-top: 1px solid var(--gray-1);
    }
    .personas-carousel__btn {
      width: 28px; height: 28px; border-radius: 50%;
      border: 1px solid var(--gray-2); background: none; cursor: pointer;
      font-size: 12px; color: var(--gray-4);
      display: flex; align-items: center; justify-content: center;
      transition: border-color .2s, background .2s;
    }
    .personas-carousel__btn:hover { border-color: var(--pink); color: var(--pink); }
    .personas-carousel__dots { display: flex; gap: 6px; }
    .personas-carousel__dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--gray-2); transition: background .2s;
    }
    .personas-carousel__dot.active { background: var(--pink); }

    /* Screen slots for Figma mockups */
    .screen-slot {
      flex-shrink: 0;
      width: 280px;
      aspect-ratio: 16/10;
      background: var(--white);
      border: 1.5px dashed var(--gray-2);
      border-radius: 10px;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      scroll-snap-align: start;
      transition: border-color .2s;
      overflow: hidden;
    }
    .screen-slot:hover { border-color: var(--pink); }
    .screen-slot img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
      border-radius: 8px;
    }
    .screen-slot__num {
      font-family: 'DM Serif Display', serif;
      font-size: 28px;
      color: var(--gray-2);
      pointer-events: none;
      user-select: none;
    }
    /* Hide number when image is present */
    .screen-slot img + .screen-slot__num { display: none; }