
  /* ======================== TOKENS ======================== */
  :root{
    --bg:        #f4f1ec;      /* warm off-white */
    --bg-alt:    #eae5dc;      /* slightly darker */
    --paper:    #faf8f5;
    --ink:       #141414;      /* near-black */
    --ink-2:     #2a2a2a;
    --muted:     #6b655c;
    --line:      rgba(20,20,20,.12);
    --line-2:    rgba(20,20,20,.06);
    --orange:    #ff6900;      /* brand accent · primary */
    --orange-2:  #e65f00;
    --accent-2:  #AF0B17;      /* brand accent · secondary */
    --serif: 'Fraunces', 'Times New Roman', serif;
    --sans:  'Inter Tight', 'Work Sans', system-ui, sans-serif;
    --mono:  ui-monospace, 'SF Mono', Menlo, monospace;
    --numerals: var(--serif);
    --num-style: normal;
    --num-weight: 340;
    --num-feature: "lnum" 1, "tnum" 0;
  }


  *{margin:0;padding:0;box-sizing:border-box}

  html{scroll-behavior:smooth}

  body{
    font-family:var(--sans);
    background:var(--bg);
    color:var(--ink);
    font-size:16px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }

  a{color:inherit;text-decoration:none}

  img{display:block;max-width:100%}

  button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}


  .wrap{max-width:1360px;margin:0 auto;padding:0 40px}

  @media(max-width:640px){.wrap{padding:0 22px}}


  /* ======================== HEADER ======================== */
  .site-header{
    position:fixed;top:0;left:0;right:0;z-index:100;
    padding:18px 0;
    background:rgba(244,241,236,0);
    backdrop-filter:blur(0);
    transition:background .3s ease, backdrop-filter .3s ease, border-color .3s ease, padding .3s ease;
    border-bottom:1px solid transparent;
  }

  .site-header.scrolled{
    background:rgba(244,241,236,.85);
    backdrop-filter:blur(14px) saturate(1.2);
    border-bottom-color:var(--line);
    padding:12px 0;
  }

  .site-header.dark-mode{ color:#fff; }

  .site-header.dark-mode.scrolled{ background:rgba(20,20,20,.8); border-bottom-color:rgba(255,255,255,.1); }


  .header-row{display:flex;align-items:center;gap:40px;justify-content:space-between}

  .brand{display:flex;align-items:center;gap:10px}

  .brand-logo{
    height:32px;width:auto;display:block;
    transition:filter .3s ease;
  }

  /* brand logo keeps its real colors in dark mode too */


  .nav{display:flex;align-items:center;gap:2px}

  .nav a, .nav .nav-label{
    padding:8px 14px;font-size:14px;font-weight:500;border-radius:999px;
    transition:background .2s, color .2s;
    position:relative;
  }

  .nav .nav-label{cursor:default;display:inline-block}

  .nav a:hover{background:rgba(20,20,20,.06)}

  .dark-mode .nav a:hover{background:rgba(255,255,255,.08)}

  .nav a.is-active{color:var(--orange)}

  .nav .has-menu{position:relative}

  .nav .has-menu > .nav-label::after, .nav .has-menu > a::after{
    content:"";display:inline-block;margin-left:6px;
    width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;
    transform:translateY(-2px) rotate(45deg);opacity:.6;
  }

  .nav .menu{
    position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(-4px);
    background:var(--paper);border:1px solid var(--line);border-radius:14px;
    padding:6px;min-width:180px;
    box-shadow:0 20px 40px -20px rgba(0,0,0,.2);
    opacity:0;pointer-events:none;transition:all .2s ease;
    color:var(--ink);
  }

  .nav .menu::before{
    content:"";position:absolute;left:0;right:0;top:-10px;height:10px;
  }

  .nav .has-menu:hover .menu, .nav .has-menu:focus-within .menu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);transition-delay:0s}
  .nav .has-menu .menu{transition-delay:.15s}

  .nav .menu a{display:block;padding:10px 14px;font-size:14px;border-radius:10px}

  .nav .menu a:hover{background:var(--bg-alt)}


  .header-cta{display:flex;align-items:center;gap:10px}

  .lang{display:flex;gap:2px;align-items:center;font-size:13px;font-weight:500;opacity:.7;margin-right:8px}

  .lang a{padding:4px 6px}

  .lang a.is-active{color:var(--orange);opacity:1}

  .btn-ghost{
    padding:9px 16px;border:1px solid currentColor;border-radius:999px;font-size:13.5px;font-weight:500;
    transition:background .2s,color .2s;
  }

  .btn-ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}

  .dark-mode .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

  .btn-solid{
    padding:10px 18px;background:var(--ink);color:var(--bg);border-radius:999px;
    font-size:13.5px;font-weight:500;display:inline-flex;align-items:center;gap:8px;
    transition:background .2s, transform .2s;
  }

  .btn-solid:hover{background:var(--orange)}

  .dark-mode .btn-solid{background:#fff;color:var(--ink)}

  .dark-mode .btn-solid:hover{background:var(--orange);color:#fff}


  /* ======================== HERO ======================== */
  .hero{
    position:relative;min-height:100vh;
    display:flex;align-items:flex-end;
    padding:120px 0 60px;
    background:#0e0e0e;
    color:#fff;
    overflow:hidden;
  }

  .hero-bg::after{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(1200px 600px at 85% 10%, rgba(255,105,0,.18), transparent 60%),
      linear-gradient(180deg, rgba(10,10,10,.7) 0%, rgba(10,10,10,.4) 35%, rgba(10,10,10,.75) 100%),
      linear-gradient(90deg, rgba(10,10,10,.75) 0%, rgba(10,10,10,.2) 60%, transparent 100%);
  }

  .hero-inner{position:relative;z-index:1;width:100%}

  .hero-eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
    color:rgba(255,255,255,.78);
    margin-bottom:28px;
    padding:6px 14px 6px 10px;border:1px solid rgba(255,255,255,.18);border-radius:999px;
    background:rgba(255,255,255,.04);backdrop-filter:blur(8px);
  }

  .hero-eyebrow .pulse{
    width:8px;height:8px;border-radius:50%;background:var(--orange);
    box-shadow:0 0 0 0 rgba(255,105,0,.6);
    animation:pulse 2s infinite;
  }

  @keyframes pulse{
    0%{box-shadow:0 0 0 0 rgba(255,105,0,.6)}
    70%{box-shadow:0 0 0 10px rgba(255,105,0,0)}
    100%{box-shadow:0 0 0 0 rgba(255,105,0,0)}
  }

  .hero h1{
    font-family:var(--serif);
    font-weight:360;
    font-size:clamp(2.6rem, 6.2vw, 5.6rem);
    line-height:.98;
    letter-spacing:-.035em;
    max-width:16ch;
    margin-bottom:30px;
  }

  .hero h1 em{font-style:italic;font-weight:360;color:var(--orange)}

  .hero h1 .thin{font-weight:300;opacity:.9}

  .hero-lede{
    max-width:48ch;font-size:clamp(1rem,1.3vw,1.15rem);
    color:rgba(255,255,255,.75);line-height:1.55;margin-bottom:40px;
  }

  .hero-ctas{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

  .btn-primary{
    padding:16px 26px;background:var(--orange);color:#fff;border-radius:999px;
    font-weight:500;font-size:15px;display:inline-flex;align-items:center;gap:12px;
    transition:transform .2s, background .2s;
  }

  .btn-primary:hover{background:#fff;color:var(--ink);transform:translateY(-1px)}

  .btn-primary .arr{transition:transform .2s}

  .btn-primary:hover .arr{transform:translateX(3px)}

  .btn-secondary{
    padding:16px 22px;color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:999px;
    font-weight:500;font-size:15px;display:inline-flex;align-items:center;gap:10px;
    transition:background .2s,border-color .2s;
  }

  .btn-secondary:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}


  .hero-meta{
    position:absolute;right:40px;bottom:60px;z-index:2;
    display:flex;flex-direction:column;gap:14px;align-items:flex-end;text-align:right;
    font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.12em;text-transform:uppercase;
  }

  .hero-meta .big{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(2.4rem, 4vw, 3.8rem);letter-spacing:-.02em;text-transform:none;
    color:#fff;line-height:.9;
  }

  .hero-meta .big sup{font-size:.4em;font-style:normal;color:var(--orange);vertical-align:top;margin-left:4px}

  @media(max-width:900px){ .hero-meta{display:none} }


  .hero-scroll{
    position:absolute;left:40px;bottom:40px;z-index:2;
    font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    color:rgba(255,255,255,.55);
    display:flex;align-items:center;gap:10px;
  }

  .hero-scroll .line{
    width:50px;height:1px;background:rgba(255,255,255,.3);position:relative;overflow:hidden;
  }

  .hero-scroll .line::after{
    content:"";position:absolute;inset:0;background:var(--orange);
    animation:scroll-line 2.4s cubic-bezier(.4,0,.2,1) infinite;
    transform-origin:left;
  }

  @keyframes scroll-line{
    0%{transform:scaleX(0);transform-origin:left}
    40%{transform:scaleX(1);transform-origin:left}
    60%{transform:scaleX(1);transform-origin:right}
    100%{transform:scaleX(0);transform-origin:right}
  }


  /* ======================== MARQUEE ======================== */
  .marquee{
    background:var(--ink);color:var(--bg);
    padding:22px 0;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.06);
  }

  .marquee-track{
    display:flex;gap:60px;align-items:center;
    animation:marquee 40s linear infinite;
    white-space:nowrap;
  }

  .marquee span{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(1.6rem,2.6vw,2.2rem);letter-spacing:-.02em;
    color:var(--bg);
  }

  .marquee .dot{width:8px;height:8px;border-radius:50%;background:var(--orange);flex:0 0 auto}

  @keyframes marquee{to{transform:translateX(-50%)}}


  /* ======================== SECTION BASE ======================== */
  section{position:relative}

  .sec-head{display:flex;gap:40px;align-items:flex-end;justify-content:space-between;margin-bottom:60px;flex-wrap:wrap}

  .sec-idx{
    font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--muted);display:flex;align-items:center;gap:12px;margin-bottom:18px;
  }

  .sec-idx::before{content:"";width:22px;height:1px;background:var(--ink);opacity:.5}

  .sec-title{
    font-family:var(--serif);font-weight:340;
    font-size:clamp(2.2rem,4.4vw,3.8rem);
    line-height:1.02;letter-spacing:-.028em;
    max-width:22ch;
  }

  .sec-title em{font-style:italic;color:var(--orange)}

  .sec-title .thin{font-weight:300;opacity:.55}

  .sec-sub{max-width:38ch;color:var(--muted);font-size:15.5px;line-height:1.6}


  /* ======================== SERVICES ======================== */
  .services{padding:120px 0;background:var(--bg)}

  .services-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
    background:var(--line);border:1px solid var(--line);border-radius:20px;overflow:hidden;
  }

  .svc{
    background:var(--paper);padding:32px 32px 36px;
    display:flex;flex-direction:column;gap:16px;
    position:relative;transition:background .3s ease;
    min-height:320px;
  }

  .svc:hover{background:var(--bg-alt)}

  .svc-thumb{
    width:100%;aspect-ratio:16/10;overflow:hidden;border-radius:12px;
    background:var(--bg-alt);margin-bottom:4px;
  }

  .svc-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(.1) contrast(1.02);transition:transform .6s cubic-bezier(.2,.6,.2,1), filter .6s}

  .svc:hover .svc-thumb img{transform:scale(1.05);filter:grayscale(0) contrast(1.05)}

  .svc-num{
    font-family:var(--mono);font-size:11px;color:var(--muted);
    letter-spacing:.18em;text-transform:uppercase;
  }

  .svc h3{
    font-family:var(--serif);font-weight:380;
    font-size:1.85rem;line-height:1.05;letter-spacing:-.02em;
  }

  .svc p{color:var(--muted);font-size:14.5px;line-height:1.6;flex:1}

  .svc-link{
    font-size:13.5px;font-weight:500;display:inline-flex;align-items:center;gap:10px;
    color:var(--ink);border-bottom:1px solid transparent;align-self:flex-start;
    padding-bottom:2px;transition:color .2s;
  }

  .svc-link:hover{color:var(--orange)}

  .svc-link .arr{transition:transform .2s}

  .svc-link:hover .arr{transform:translateX(4px)}



  /* ======================== SPOTLIGHT (Mentoria) ======================== */
  .spotlight{padding:0 0 120px;background:var(--bg)}

  .spot-card{
    display:grid;grid-template-columns:1.05fr .95fr;gap:0;
    background:var(--ink);color:#fff;border-radius:24px;overflow:hidden;
    position:relative;
    isolation:isolate;
  }

  .spot-media{position:relative;min-height:520px;overflow:hidden;background:#111}

  .spot-media img{
    width:100%;height:100%;object-fit:cover;position:absolute;inset:0;
    filter:grayscale(.25) contrast(1.05) brightness(.85);
    transition:transform .8s cubic-bezier(.2,.6,.2,1), filter .8s;
  }

  .spot-card:hover .spot-media img{transform:scale(1.04);filter:grayscale(0) contrast(1.05) brightness(1)}

  .spot-media::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(135deg, transparent 40%, rgba(20,20,20,.5));
  }

  .spot-badge{
    position:absolute;top:26px;left:26px;z-index:2;
    font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    color:#fff;display:inline-flex;align-items:center;gap:10px;
    padding:8px 14px;background:rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.15);
    border-radius:999px;backdrop-filter:blur(8px);
  }

  .spot-badge .sq{width:8px;height:8px;background:var(--orange)}

  .spot-body{
    padding:64px 56px;display:flex;flex-direction:column;justify-content:center;
    position:relative;
  }

  .spot-body .kicker{font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin-bottom:20px}

  .spot-body h2{
    font-family:var(--serif);font-weight:340;
    font-size:clamp(2rem,3.4vw,3rem);line-height:1.02;letter-spacing:-.028em;
    margin-bottom:24px;
  }

  .spot-body h2 em{font-style:italic}

  .spot-body p{color:rgba(255,255,255,.7);font-size:16px;line-height:1.65;margin-bottom:28px;max-width:42ch}

  .spot-meta{
    display:grid;grid-template-columns:1fr 1fr;gap:18px 28px;
    margin:4px 0 36px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);
  }

  .spot-meta-item .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:6px}

  .spot-meta-item .v{font-size:15px;color:#fff;font-weight:500}

  .spot-cta{
    align-self:flex-start;
    padding:14px 22px;background:var(--orange);color:#fff;border-radius:999px;
    font-weight:500;font-size:14.5px;display:inline-flex;align-items:center;gap:12px;
    transition:background .2s, transform .2s;
  }

  .spot-cta:hover{background:#fff;color:var(--ink);transform:translateY(-1px)}


  /* ======================== ABOUT / STATS ======================== */
  .about{padding:120px 0;background:var(--bg-alt);position:relative;overflow:hidden}

  .about::before{
    content:"";position:absolute;top:-40px;left:50%;transform:translateX(-50%);
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(10rem,22vw,22rem);color:rgba(20,20,20,.035);
    letter-spacing:-.05em;pointer-events:none;line-height:1;
    white-space:nowrap;
  }

  .about-inner{display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}

  .about-img-wrap{
    position:relative;aspect-ratio:3/2;border-radius:20px;overflow:hidden;
  }

  .about-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center 35%}

  .about-img-wrap .chip{
    position:absolute;left:20px;bottom:20px;
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    background:rgba(250,248,245,.92);color:var(--ink);
    padding:10px 14px;border-radius:999px;backdrop-filter:blur(6px);
  }

  .about-body .kicker{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:22px;display:flex;align-items:center;gap:12px}

  .about-body .kicker::before{content:"";width:22px;height:1px;background:var(--ink);opacity:.5}

  .about-body h2{
    font-family:var(--serif);font-weight:340;
    font-size:clamp(2.2rem,4.2vw,3.6rem);line-height:1;letter-spacing:-.03em;
    margin-bottom:30px;
  }

  .about-body h2 em{font-style:italic;color:var(--orange)}

  .about-body p{color:var(--ink-2);font-size:17px;line-height:1.6;margin-bottom:18px;max-width:48ch}

  .about-body p.lead{font-size:20px;color:var(--ink);font-weight:400;line-height:1.5}


  .stats{
    display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    margin:44px 0 36px;padding:32px 0;
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  }

  .stat{padding-right:20px}

  .stat + .stat{padding-left:28px;border-left:1px solid var(--line)}

  .stat .num{
    font-family:var(--numerals);font-weight:var(--num-weight);font-style:var(--num-style);font-feature-settings:var(--num-feature);font-size:clamp(2.4rem,3.6vw,3.4rem);
    line-height:1;letter-spacing:-.02em;color:var(--ink);
  }

  .stat .num em{font-style:italic;color:var(--orange)}

  .stat .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:10px}


  .about-link{
    display:inline-flex;align-items:center;gap:12px;font-weight:500;font-size:15px;
    padding:14px 22px;border:1px solid var(--ink);border-radius:999px;
    transition:background .2s, color .2s;
  }

  .about-link:hover{background:var(--ink);color:var(--bg)}


  /* ======================== SOLUTIONS DUO ======================== */
  .duo{padding:120px 0;background:var(--bg)}

  .duo-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:20px}

  .duo-card{
    position:relative;border-radius:22px;overflow:hidden;
    min-height:440px;
    padding:44px;display:flex;flex-direction:column;justify-content:space-between;
    color:#fff;isolation:isolate;cursor:pointer;
    transition:transform .4s cubic-bezier(.2,.6,.2,1);
  }

  .duo-card::before{
    content:"";position:absolute;inset:0;z-index:-2;
    background-size:cover;background-position:center;
    transition:transform .8s cubic-bezier(.2,.6,.2,1);
  }

  .duo-card::after{
    content:"";position:absolute;inset:0;z-index:-1;
    background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 60%, rgba(0,0,0,.85) 100%);
  }

  .duo-card:hover::before{transform:scale(1.05)}

  .duo-card:hover{transform:translateY(-4px)}

  .duo-num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.8}

  .duo-card h3{
    font-family:var(--serif);font-weight:340;font-size:clamp(2rem,3.2vw,2.8rem);
    line-height:1.02;letter-spacing:-.028em;margin-bottom:14px;
  }

  .duo-card h3 em{font-style:italic;color:var(--orange)}

  .duo-card p{font-size:15px;line-height:1.55;opacity:.82;max-width:40ch;margin-bottom:28px}

  .duo-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px}

  .duo-cta{
    font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:10px;
    padding:12px 20px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
    border-radius:999px;backdrop-filter:blur(8px);transition:all .2s;
  }

  .duo-card:hover .duo-cta{background:var(--orange);border-color:var(--orange)}

  .duo-tags{display:flex;gap:6px;flex-wrap:wrap}

  .duo-tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;padding:5px 10px;border:1px solid rgba(255,255,255,.25);border-radius:999px;opacity:.8}


  /* ======================== CTA (Phone) ======================== */
  .ctabar{background:var(--ink);color:#fff;padding:100px 0;position:relative;overflow:hidden}

  .ctabar-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center}

  .ctabar .kicker{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:22px;display:flex;align-items:center;gap:12px}

  .ctabar .kicker::before{content:"";width:22px;height:1px;background:var(--orange)}

  .ctabar h2{
    font-family:var(--serif);font-weight:340;
    font-size:clamp(2.4rem,5vw,4.4rem);line-height:1;letter-spacing:-.03em;
    margin-bottom:28px;
  }

  .ctabar h2 em{font-style:italic}

  .ctabar p{color:rgba(255,255,255,.65);font-size:17px;line-height:1.6;max-width:46ch;margin-bottom:36px}

  .phone-line{
    display:inline-flex;align-items:center;gap:18px;
    padding:22px 28px;background:var(--orange);color:#fff;border-radius:999px;
    text-decoration:none;transition:transform .2s, background .2s;
  }

  .phone-line:hover{background:#fff;color:var(--ink);transform:translateY(-2px)}

  .phone-line .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;opacity:.8}

  .phone-line .num{font-family:var(--serif);font-size:clamp(1.5rem,2.3vw,1.9rem);font-weight:400;letter-spacing:-.01em}

  .ctabar-visual{
    aspect-ratio:1/1;max-width:440px;margin-left:auto;
    position:relative;border-radius:50%;overflow:hidden;
    border:1px solid rgba(255,255,255,.1);
  }

  .ctabar-visual img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) contrast(1.05)}

  .ctabar-visual::after{
    content:"";position:absolute;inset:0;border-radius:50%;
    background:radial-gradient(circle at 30% 30%, transparent 50%, rgba(255,105,0,.25));
  }

  .ring{
    position:absolute;inset:-40px;border-radius:50%;
    border:1px dashed rgba(255,255,255,.12);
    animation:spin 60s linear infinite;pointer-events:none;
  }

  .ring span{
    position:absolute;top:-6px;left:50%;width:12px;height:12px;background:var(--orange);
    border-radius:50%;transform:translateX(-50%);
  }

  @keyframes spin{to{transform:rotate(360deg)}}


  /* ======================== TESTIMONIALS ======================== */
  .quotes{padding:120px 0;background:var(--bg);position:relative}

  .quotes .sec-head{margin-bottom:30px}

  .quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}

  .quote{
    background:var(--paper);border:1px solid var(--line-2);border-radius:20px;
    padding:40px 34px 34px;
    display:flex;flex-direction:column;gap:22px;min-height:340px;
    position:relative;transition:border-color .25s, transform .25s;
  }

  .quote:hover{border-color:rgba(20,20,20,.2);transform:translateY(-3px)}

  .quote-mark{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:80px;line-height:.6;color:var(--orange);
    margin-bottom:-10px;
  }

  .quote-text{
    font-family:var(--serif);font-weight:340;
    font-size:19px;line-height:1.35;letter-spacing:-.01em;color:var(--ink);
    flex:1;
  }

  .quote-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--line-2)}

  .quote-author img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex:0 0 auto}

  .quote-author .n{font-weight:500;font-size:14.5px;color:var(--ink);line-height:1.25}

  .quote-author .r{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:3px}


  /* ======================== FOOTER ======================== */
  .footer{background:var(--ink);color:#ddd;padding:100px 0 40px;position:relative;overflow:hidden}

  .footer-big{
    font-family:var(--serif);font-weight:340;font-style:normal;
    font-size:clamp(3rem,12.5vw,12rem);line-height:.92;letter-spacing:-.04em;
    color:#fff;white-space:nowrap;
    margin:0 0 80px;
    padding:0;
    text-align:center;
    width:100%;
  }

  .footer-big em{font-style:italic;color:var(--orange)}

  .footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:50px;margin-bottom:60px;justify-items:start;width:100%;padding:0 5px;box-sizing:border-box}
  .footer-grid > div:nth-child(2){justify-self:center}
  .footer-grid > div:nth-child(3){justify-self:center}
  .footer-grid > div:nth-child(4){justify-self:end}
  .footer-grid address{text-align:left;font-size:17px;line-height:1.75}
  .footer-grid .footer-list{align-items:flex-start;gap:12px}
  .footer-grid .footer-list a{font-size:17px}
  .footer-grid h4{font-size:13px !important;letter-spacing:.2em;margin-bottom:24px !important}

  .footer h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#fff;margin-bottom:20px;font-weight:500}

  .footer a{color:rgba(255,255,255,.62);font-size:14.5px;transition:color .2s}

  .footer a:hover{color:var(--orange)}

  .footer-list{list-style:none;display:flex;flex-direction:column;gap:10px}

  .footer address{font-style:normal;color:rgba(255,255,255,.62);font-size:14.5px;line-height:1.7;margin-bottom:16px}

  .footer-bottom{
    display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;
    padding-top:32px;border-top:1px solid rgba(255,255,255,.1);
    font-size:13px;color:rgba(255,255,255,.5);
  }

  .footer-bottom .brand{color:#fff}


  /* ======================== RESPONSIVE ======================== */
  @media (max-width:1450px){
    /* Header: hamburger a partir de 1450px */
        .nav, .header-cta .btn-ghost, .lang{display:none}
        .hamburger{display:inline-flex !important}
  }
  @media(max-width:1100px){
    .services-grid{grid-template-columns:1fr 1fr}
    .spot-card{grid-template-columns:1fr}
    .spot-media{min-height:360px}
    .about-inner{grid-template-columns:1fr;gap:50px}
    .about-img-wrap{max-width:420px}
    .team-grid{grid-template-columns:repeat(6,1fr)}
    .team-card{grid-column:span 3}
    .team-card--lead{grid-column:span 6}
    .why-list{grid-template-columns:1fr}
    .why-list li{padding:26px 0 !important;border-right:0 !important;padding-left:0 !important}
    .ctabar-grid{grid-template-columns:1fr;gap:50px}
    .ctabar-visual{margin:0 auto}
    .duo-grid{grid-template-columns:1fr}
    .quotes-grid{grid-template-columns:1fr 1fr}
    .footer-grid{grid-template-columns:1fr 1fr;gap:40px 60px;padding:0}
    .footer-grid > div:nth-child(n){justify-self:start}
    .footer-big{margin:0 0 64px}
  }
@media(max-width:760px){
    .services-grid{grid-template-columns:1fr}
    .stats{grid-template-columns:1fr 1fr}
    .stat:nth-child(3){grid-column:span 2;border-left:0;padding-left:0;padding-top:20px;margin-top:20px;border-top:1px solid var(--line)}
    .quotes-grid{grid-template-columns:1fr}
    .spot-body{padding:40px 28px}
    .footer-grid{grid-template-columns:1fr;gap:32px;padding:0}
    .footer-grid > div:nth-child(n){justify-self:start !important}
    .footer-big{font-size:clamp(2.2rem,11vw,4rem);white-space:normal;line-height:.98;margin:0 0 36px}
    .hero{padding:140px 0 80px}
  }


  /* ======================== TWEAKS PANEL ======================== */
  #tweaks{
    position:fixed;bottom:20px;right:20px;z-index:9999;
    background:var(--paper);border:1px solid var(--line);border-radius:18px;
    padding:18px;width:320px;box-shadow:0 30px 60px -20px rgba(0,0,0,.25);
    font-family:var(--sans);color:var(--ink);display:none;
    max-height:calc(100vh - 40px);overflow-y:auto;
  }

  #tweaks.on{display:block}

  #tweaks h3{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:14px;color:var(--muted)}

  .tweak-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;font-size:13px}

  .tweak-row:last-child{margin-bottom:0}

  .tweak-row label{font-weight:500}

  .swatch-row{display:flex;gap:6px}

  .swatch{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s}

  .swatch.sel{border-color:var(--ink)}

  .swatch:hover{transform:scale(1.1)}

  .seg{display:flex;background:var(--bg-alt);border-radius:999px;padding:3px;gap:2px}

  .seg button{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:500;color:var(--muted)}

  .seg button.sel{background:var(--ink);color:#fff}

  .seg-grid{display:grid;grid-template-columns:1fr 1fr;border-radius:12px;padding:4px;gap:4px}

  .seg-grid button{text-align:left;padding:8px 10px;border-radius:8px;display:flex;flex-direction:column;gap:2px;line-height:1.15}

  .seg-grid button .ft-hint{font-family:ui-monospace,Menlo,monospace;font-size:9.5px;opacity:.65;letter-spacing:.04em}

  #tweaks{width:320px;max-height:calc(100vh - 40px);overflow-y:auto}




/* Mobile menu — hidden by default on all viewports */
.mobile-menu{
  position:fixed;inset:0;z-index:200;
  background:var(--bg);color:var(--ink);
  padding:90px 28px 40px;
  transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.6,.2,1);
  display:flex;flex-direction:column;gap:4px;overflow-y:auto;
  visibility:hidden;
}
.mobile-menu.open{transform:translateY(0);visibility:visible}
.mobile-menu a{
  font-family:var(--serif);font-weight:300;font-size:32px;letter-spacing:-.02em;
  padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;text-decoration:none;
}
.mobile-menu a .arr{font-family:var(--mono);font-size:14px;color:var(--muted)}
.mobile-menu a.sub{padding-left:18px;font-size:22px;opacity:.8}
.mobile-menu a.disabled{opacity:.35;pointer-events:none}
.mobile-menu .mm-group-label{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin:22px 0 6px;
}
.mobile-menu .mm-ctas{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.mobile-menu .mm-ctas a{
  font-family:var(--sans);font-size:15px;font-weight:500;letter-spacing:0;
  padding:16px 22px;border-radius:999px;border:1px solid var(--line);
  justify-content:center;
}
.mobile-menu .mm-ctas a.primary{background:var(--orange);color:#fff;border-color:var(--orange)}

/* ============ RESPONSIVE OVERRIDES ============ */
@media (max-width: 1100px){
  .wrap{padding:0 32px}
  .hero h1{font-size:clamp(2.4rem, 7vw, 4.6rem);max-width:14ch}
  .subhero h1{font-size:clamp(2.6rem, 8vw, 5rem);max-width:14ch}
  .section h2, .pillar h2, .cta-band h2{font-size:clamp(2rem, 5.2vw, 3.4rem)}
  .footer-big{font-size:clamp(2.4rem,10.5vw,7.5rem);white-space:nowrap}
  .feature-grid{gap:20px}
  .team-grid{gap:16px}
  .team-card--lead h3{font-size:28px}
}

@media (max-width: 760px){
  /* — Global — */
  .wrap{padding:0 20px}
  html{font-size:15px}
  body{overflow-x:hidden}

  /* — Header: hamburger — */
  .site-header{padding:14px 0}
  .site-header.scrolled{padding:10px 0}
  .header-row{gap:16px}
  .brand-logo{height:26px}
  .nav{display:none}
  .header-cta .btn-ghost{display:none}
  .header-cta .lang{display:none}
  .header-cta .btn-solid{padding:10px 14px;font-size:13px}
  /* — Mobile overlay menu — */
  .mobile-menu{
    position:fixed;inset:0;z-index:200;
    background:var(--bg);color:var(--ink);
    padding:90px 28px 40px;
    transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.6,.2,1);
    display:flex;flex-direction:column;gap:4px;overflow-y:auto;
  }
  .mobile-menu.open{transform:translateY(0)}
  .mobile-menu a{
    font-family:var(--serif);font-weight:300;font-size:32px;letter-spacing:-.02em;
    padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);
    display:flex;align-items:center;justify-content:space-between;
  }
  .mobile-menu a .arr{font-family:var(--mono);font-size:14px;color:var(--muted)}
  .mobile-menu a.sub{padding-left:18px;font-size:22px;opacity:.8}
  .mobile-menu a.disabled{opacity:.35;pointer-events:none}
  .mobile-menu .mm-group-label{
    font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--muted);margin:22px 0 6px;
  }
  .mobile-menu .mm-ctas{display:flex;flex-direction:column;gap:10px;margin-top:28px}
  .mobile-menu .mm-ctas a{
    font-family:var(--sans);font-size:15px;font-weight:500;letter-spacing:0;
    padding:16px 22px;border-radius:999px;border:1px solid var(--line);
    justify-content:center;
  }
  .mobile-menu .mm-ctas a.primary{background:var(--orange);color:#fff;border-color:var(--orange)}

  /* — Hero — */
  .hero{padding:120px 0 70px;min-height:auto}
  .hero h1{font-size:clamp(2.2rem,10vw,3.8rem);max-width:none;margin-bottom:20px;letter-spacing:-.03em}
  .hero-eyebrow{font-size:10px;padding:5px 12px 5px 8px}
  .hero-lede{font-size:15px;margin-bottom:28px;max-width:none}
  .hero-cta{display:flex;flex-wrap:wrap;gap:10px}
  .hero-cta .btn-primary, .hero-cta .btn-ghost{padding:14px 20px;font-size:14px}
  .hero-meta{display:none}
  .hero-scroll{display:none}

  /* — Subpage hero — */
  .subhero{min-height:auto;padding:120px 0 70px}
  .subhero h1{font-size:clamp(2.2rem,10vw,3.8rem);max-width:none;margin-bottom:20px}
  .subhero .lede{font-size:15px}
  .subhero .eyebrow{font-size:10px;padding:7px 14px}
  .crumb{font-size:10px}

  /* — Sections — */
  .section{padding:70px 0}
  .section h2{font-size:clamp(1.8rem,7.5vw,2.6rem);margin-bottom:24px}
  .section .lede-p{font-size:16px}
  .split{grid-template-columns:1fr !important;gap:28px}
  .pillar{padding:60px 0}
  .pillar .wrap{grid-template-columns:1fr !important;gap:28px}
  .pillar h2{font-size:clamp(1.8rem,7vw,2.4rem)}

  /* — Feature grid — */
  .feature-grid{grid-template-columns:1fr;gap:14px;margin-top:28px}
  .feature{padding:22px}
  .feature h3{font-size:21px}

  /* — Team — */
  .team-grid{grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
  .team-card{grid-column:span 1}
  .team-card--lead{grid-column:1 / -1}
  .team-card--lead h3{font-size:26px}
  .team-info h3{font-size:20px}
  .team-info{padding:16px 16px 20px}

  /* — Why band — */
  .why-band{padding:80px 0}
  .why-head{margin-bottom:40px}
  .why-list li{gap:16px;padding:22px 0}
  .why-list h3{font-size:1.15rem}
  .why-list p{font-size:14px}

  /* — Bullets — */
  .bullets li{grid-template-columns:auto 1fr;gap:14px;padding:20px 0}
  .bullets .meta{display:none}
  .bullets h4{font-size:18px}
  .bullets p{font-size:14px}

  /* — Home-specific grids — */
  .services-grid{grid-template-columns:1fr !important}
  .spot-card{grid-template-columns:1fr !important}
  .spot-media{min-height:240px !important}
  .spot-body{padding:34px 24px !important}
  .about-inner{grid-template-columns:1fr !important;gap:32px}
  .about-img-wrap{max-width:100% !important}
  .stats{grid-template-columns:1fr !important}
  .stat{border-left:0 !important;border-top:1px solid var(--line);padding:20px 0 !important;margin:0 !important}
  .stat:first-child{border-top:0}
  .stat .num{font-size:2.2rem !important}
  .duo-grid{grid-template-columns:1fr !important;gap:16px}
  .duo-card{min-height:360px;padding:28px}
  .quotes-grid{grid-template-columns:1fr !important;gap:20px}
  .ctabar-grid{grid-template-columns:1fr !important;gap:34px}
  .ctabar{padding:70px 0}
  .ctabar-visual{margin:0 auto;max-width:260px}
  .marquee{padding:16px 0;font-size:14px}

  /* — Footer — */
  .footer{padding:70px 0 30px}
  .footer-grid{grid-template-columns:1fr !important;gap:32px !important;padding:0 !important}
  .footer-grid > div:nth-child(n){justify-self:start !important}
  .footer-big{font-size:clamp(2.2rem,11vw,4rem) !important;margin:0 0 36px !important;padding:0;white-space:normal !important;line-height:.98 !important}
  .footer-bottom{flex-direction:column;align-items:flex-start !important;gap:14px !important;font-size:11.5px;padding-top:28px}
  .footer-grid h4{margin-bottom:16px !important;font-size:12px !important}
  .footer-grid address,.footer-grid .footer-list a{font-size:15px}
  .footer-grid .footer-list{gap:10px}

  /* — CTA band on subpages — */
  .cta-band{padding:70px 0;margin-top:0}
  .cta-band h2{font-size:clamp(1.8rem,7vw,2.4rem)}
  .cta-band .row{gap:10px}
  .cta-band .row a{padding:14px 20px !important;font-size:14px !important}

  /* — Tweaks panel — */
  #tweaks{width:calc(100vw - 32px);bottom:16px;right:16px;left:16px}

  /* — Buttons — */
  .btn-primary, .btn-ghost, .btn-solid{font-size:14px}
}

@media (max-width: 420px){
  .wrap{padding:0 16px}
  .brand-logo{height:22px}
  .header-cta .btn-solid{padding:8px 12px;font-size:12px}
  .mobile-menu a{font-size:26px}
}

/* Hamburger button: hidden on desktop */
.hamburger{
  display:none;width:42px;height:42px;border-radius:50%;
  align-items:center;justify-content:center;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  transition:background .2s, transform .2s;
  flex:0 0 auto;margin-left:auto;
}
.hamburger:hover{background:rgba(255,255,255,.16)}
.scrolled .hamburger{background:rgba(20,20,20,.06);border-color:var(--line)}
.hamburger span{display:block;width:18px;height:2px;background:currentColor;position:relative;transition:transform .25s}
.hamburger span::before,.hamburger span::after{
  content:"";position:absolute;left:0;right:0;height:2px;background:currentColor;
  transition:transform .25s, top .25s;
}
.hamburger span::before{top:-6px}
.hamburger span::after{top:6px}
.hamburger.open span{background:transparent}
.hamburger.open span::before{top:0;transform:rotate(45deg)}
.hamburger.open span::after{top:0;transform:rotate(-45deg)}

/* FINAL — mobile menu base (no media query) */
.mobile-menu{position:fixed !important;inset:0;z-index:200;background:var(--bg);color:var(--ink);padding:90px 28px 40px;transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.6,.2,1);display:flex;flex-direction:column;gap:4px;overflow-y:auto;visibility:hidden}
.mobile-menu.open{transform:translateY(0) !important;visibility:visible !important}
.mobile-menu a{font-family:var(--serif);font-weight:300;font-size:32px;letter-spacing:-.02em;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);display:flex;align-items:center;justify-content:space-between;text-decoration:none}
.mobile-menu a .arr{font-family:var(--mono);font-size:14px;color:var(--muted)}
.mobile-menu a.sub{padding-left:18px;font-size:22px;opacity:.8}
.mobile-menu a.disabled{opacity:.35;pointer-events:none}
.mobile-menu .mm-group-label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:22px 0 6px}
.mobile-menu .mm-ctas{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.mobile-menu .mm-ctas a{font-family:var(--sans);font-size:15px;font-weight:500;letter-spacing:0;padding:16px 22px;border-radius:999px;border:1px solid var(--line);justify-content:center}
.mobile-menu .mm-ctas a.primary{background:var(--orange);color:#fff;border-color:var(--orange)}


  /* ======================== MENTORIA IA ======================== */

  /* section "Com ho fem" — 3 step cards + supporting image */
  .mentoria-steps{
    display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:stretch;
  }
  .mentoria-steps-grid{
    display:grid;grid-template-columns:1fr;gap:18px;
  }
  .step-card{
    background:var(--paper);
    border:1px solid var(--line-2);
    border-radius:18px;
    padding:28px 32px;
    display:grid;grid-template-columns:auto 1fr;column-gap:28px;row-gap:6px;
    align-items:start;
    transition:border-color .25s, transform .25s;
  }
  .step-card:hover{border-color:var(--line);transform:translateY(-2px)}
  .step-card .step-num{
    grid-row:span 2;
    font-family:var(--serif);font-weight:340;font-style:italic;
    font-size:48px;line-height:.9;color:var(--orange);
    letter-spacing:-.02em;min-width:72px;
  }
  .step-card h3{
    font-family:var(--serif);font-weight:360;font-style:normal;
    font-size:22px;line-height:1.15;color:var(--ink);margin:0;
    letter-spacing:-.015em;
  }
  .step-card p{
    color:var(--muted);font-size:15px;line-height:1.55;margin:0;
    max-width:52ch;
  }
  .mentoria-steps-img{
    position:relative;border-radius:20px;overflow:hidden;
    min-height:100%;
  }
  .mentoria-steps-img img{
    width:100%;height:100%;object-fit:cover;display:block;
  }

  /* testimoni dins "Què inclou" */
  .mentoria-quote{
    margin:40px 0 0;padding:32px 36px;
    background:var(--paper);
    border:1px solid var(--line-2);
    border-radius:20px;
    position:relative;
  }
  .mentoria-quote blockquote{
    margin:0;position:relative;padding-left:52px;
  }
  .mentoria-quote .q-mark{
    position:absolute;left:0;top:-8px;
    font-family:var(--serif);font-style:italic;font-weight:340;
    font-size:64px;line-height:1;color:var(--orange);
  }
  .mentoria-quote blockquote p{
    font-family:var(--serif);font-weight:340;font-style:italic;
    font-size:22px;line-height:1.35;color:var(--ink);
    letter-spacing:-.01em;margin:0;
    text-wrap:pretty;
  }
  .mentoria-quote figcaption{
    margin-top:20px;padding-left:52px;
    display:flex;flex-direction:column;gap:2px;
  }
  .mentoria-quote figcaption strong{
    font-family:var(--sans);font-weight:500;font-size:13px;
    color:var(--ink);letter-spacing:.02em;
  }
  .mentoria-quote figcaption span{
    font-family:var(--mono);font-size:11px;letter-spacing:.14em;
    text-transform:uppercase;color:var(--muted);
  }

  /* responsive */
  @media(max-width:1100px){
    .mentoria-steps{grid-template-columns:1fr;gap:32px}
    .mentoria-steps-img{aspect-ratio:16/9;min-height:0}
  }
  @media(max-width:760px){
    .step-card{padding:22px 22px;column-gap:18px}
    .step-card .step-num{font-size:38px;min-width:56px}
    .step-card h3{font-size:19px}
    .mentoria-quote{padding:26px 24px}
    .mentoria-quote blockquote{padding-left:40px}
    .mentoria-quote .q-mark{font-size:50px}
    .mentoria-quote blockquote p{font-size:18px}
    .mentoria-quote figcaption{padding-left:40px}
  }



/* ─────────────────────────────────────────────── */


  /* page-specific */
  .subhero{
    position:relative;min-height:62vh;
    padding:180px 0 100px;
    background:var(--ink);color:#fff;
    overflow:hidden;display:flex;align-items:flex-end;
  }
  .subhero::before{content:"";position:absolute;inset:0;z-index:0;background:#0e0e0e;opacity:1}
  .subhero::after{content:"";position:absolute;inset:0;z-index:1;background:transparent;pointer-events:none}
  .subhero > *{position:relative;z-index:2}
  .subhero .wrap{width:100%}
  .subhero .eyebrow{
    display:inline-flex;align-items:center;gap:12px;
    padding:10px 18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
    border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    margin-bottom:28px;
  }
  .subhero .eyebrow .sq{width:8px;height:8px;background:var(--accent-2);display:inline-block}
  .subhero h1{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(48px, 8vw, 108px);
    line-height:.96;letter-spacing:-.02em;
    margin-bottom:28px;max-width:14ch;
  }
  .subhero h1 em{font-style:italic;color:var(--orange);font-weight:400}
  .subhero .lede{
    font-size:clamp(18px,1.4vw,22px);line-height:1.5;
    max-width:58ch;color:rgba(255,255,255,.8);
  }

  /* content section utilities */
  .section{padding:120px 0;position:relative}
  .section-num{
    font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--muted);margin-bottom:18px;display:flex;align-items:center;gap:12px;
  }
  .section-num::before{content:"";width:22px;height:1px;background:currentColor}
  .section h2{
    font-family:var(--serif);font-weight:300;
    font-size:clamp(40px,5vw,76px);line-height:1.02;letter-spacing:-.02em;
    margin-bottom:40px;max-width:20ch;
  }
  .section h2 em{font-style:italic;color:var(--orange);font-weight:400}
  .section .lede-p{font-size:19px;line-height:1.55;max-width:62ch;color:var(--ink-2)}

  .split{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;align-items:start}
  @media(max-width:900px){.split{grid-template-columns:1fr;gap:40px}}

  .feature-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px,1fr));gap:28px;margin-top:48px}
  .feature{
    background:var(--paper);border:1px solid var(--line);border-radius:18px;
    padding:32px;transition:transform .3s ease, border-color .3s ease;
  }
  .feature:hover{transform:translateY(-4px);border-color:var(--orange)}
  .feature .num{
    font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--accent-2);margin-bottom:18px;
  }
  .feature h3{font-family:var(--serif);font-weight:400;font-size:26px;line-height:1.15;margin-bottom:12px;letter-spacing:-.01em}
  .feature p{color:var(--muted);line-height:1.55;font-size:15px}

  /* — Team grid — */
  .team-grid{
    display:grid;grid-template-columns:repeat(3,minmax(0,300px));gap:32px;margin-top:48px;justify-content:start;
  }
  .team-card{
    grid-column:auto;
    background:var(--paper);border:1px solid var(--line);border-radius:18px;
    overflow:hidden;display:flex;flex-direction:column;
    transition:transform .3s ease, border-color .3s ease;
  }
  .team-card:hover{transform:translateY(-4px);border-color:var(--orange)}
  .team-card--lead{grid-column:auto}
  .team-card--lead .team-avatar{aspect-ratio:4/5;width:100%;margin:0}
  .team-card--lead .team-info{padding:20px}
  .team-card--lead h3{font-size:22px}
  /* Featured row: photo cards (3 per row) */
  .team-card--feat{grid-column:auto;max-width:none;justify-self:stretch;width:100%}
  .team-card--feat .team-avatar{aspect-ratio:4/5;width:100%}
  /* row 2 reset — default 3-col grid handles it */
  .team-card--feat:nth-of-type(4){grid-column:auto}
  .team-card--feat:nth-of-type(5){grid-column:auto}
  /* Ghost / placeholder row: 2 cards, narrower, subtler */
  .team-card--ghost{grid-column:span 3;background:var(--paper);border:1px solid var(--line)}
  .team-card--ghost .team-avatar{aspect-ratio:4/5;background:var(--bg-alt)}
  .team-card--ghost .team-avatar svg{opacity:.55}
  .team-card--ghost .team-info{padding:18px 20px 22px;text-align:left}
  .team-card--ghost h3{font-size:20px}
  .team-card--ghost:hover{transform:translateY(-4px);border-color:var(--orange)}
  .team-row-ghost{grid-column:4 / span 6;display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}
  .team-row-ghost > .team-card--ghost{grid-column:auto}

  .team-avatar{
    position:relative;aspect-ratio:4/5;overflow:hidden;
    background:var(--bg-alt);
    display:flex;align-items:center;justify-content:center;
  }
  .team-avatar svg{width:100%;height:100%;object-fit:cover;display:block}
  .team-initials{
    position:absolute;right:14px;bottom:12px;
    font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    background:rgba(250,248,245,.92);color:var(--ink);
    padding:6px 10px;border-radius:999px;backdrop-filter:blur(6px);
  }
  .team-info{padding:22px 22px 26px}
  .team-role{
    font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--accent-2);margin-bottom:10px;
  }
  .team-info h3{
    font-family:var(--serif);font-weight:400;font-size:26px;line-height:1.1;
    letter-spacing:-.01em;margin-bottom:10px;
  }
  .team-info p{color:var(--muted);line-height:1.55;font-size:14.5px}

  /* — Why us band (dark) — */
  .why-band{
    margin:0;padding:140px 0;
    background:var(--ink);color:#fff;
    position:relative;overflow:hidden;
  }
  .why-band::before{
    content:"";position:absolute;top:-60px;right:-40px;
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(10rem,26vw,26rem);color:rgba(255,255,255,.04);
    letter-spacing:-.05em;pointer-events:none;line-height:1;
    white-space:nowrap;content:"05";
  }
  .why-head{max-width:820px;margin-bottom:72px;position:relative;z-index:1}
  .why-head h2{
    font-family:var(--serif);font-weight:340;
    font-size:clamp(2.2rem,4.6vw,4rem);line-height:1;letter-spacing:-.03em;
    color:#fff;margin:18px 0 22px;
  }
  .why-head h2 em{font-style:italic;color:var(--orange)}
  .why-lede{
    font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(1.15rem,1.5vw,1.35rem);line-height:1.5;
    color:rgba(255,255,255,.72);max-width:56ch;
  }
  .why-list{
    list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:0;
    border-top:1px solid rgba(255,255,255,.12);position:relative;z-index:1;
  }
  .why-list li{
    display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;
    padding:32px 36px 32px 0;border-bottom:1px solid rgba(255,255,255,.12);
  }
  .why-list li:nth-child(odd){padding-right:56px;border-right:1px solid rgba(255,255,255,.12)}
  .why-list li:nth-child(even){padding-left:56px}
  .why-n{
    font-family:var(--mono);font-size:12px;letter-spacing:.18em;
    color:var(--orange);padding-top:6px;
  }
  .why-list h3{
    font-family:var(--serif);font-weight:340;font-size:clamp(1.35rem,1.8vw,1.7rem);
    line-height:1.15;letter-spacing:-.01em;margin-bottom:10px;color:#fff;
  }
  .why-list p{color:rgba(255,255,255,.65);font-size:15px;line-height:1.55;max-width:52ch}

  .bullets{list-style:none;margin-top:32px;border-top:1px solid var(--line)}
  .bullets li{
    display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:start;
    padding:26px 0;border-bottom:1px solid var(--line);
  }
  .bullets .no{font-family:var(--mono);font-size:12px;color:var(--accent-2);letter-spacing:.14em;padding-top:4px}
  .bullets h4{font-family:var(--serif);font-weight:400;font-size:22px;letter-spacing:-.01em;margin-bottom:6px}
  .bullets p{color:var(--muted);font-size:15px;line-height:1.55;max-width:62ch}
  .bullets .meta{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);padding-top:6px;text-align:right}

  .alt-bg{background:var(--bg-alt)}

  .cta-band{
    margin:0;padding:140px 0 120px;
    background:var(--ink);color:#fff;
    position:relative;overflow:hidden;
  }
  .cta-band h2{font-family:var(--serif);font-weight:300;font-size:clamp(36px,4.5vw,64px);line-height:1.02;letter-spacing:-.02em;max-width:20ch;margin-bottom:36px}
  .cta-band h2 em{font-style:italic;color:var(--orange);font-weight:400}
  .cta-band .kicker{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:22px;display:flex;align-items:center;gap:12px}
  .cta-band .kicker::before{content:"";width:22px;height:1px;background:var(--orange)}
  .cta-band .row{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
  .cta-band .row .btn-primary{background:var(--orange);color:#fff}
  .cta-band .row .btn-ghost{border-color:rgba(255,255,255,.22);color:#fff}
  .cta-band .row .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
  .cta-band .row .btn-primary:hover{background:#fff;color:var(--ink);transform:translateY(-1px)}

  .crumb{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:22px}
  .crumb a{color:rgba(255,255,255,.75);text-decoration:none}
  .crumb a:hover{color:#fff}
  .crumb .sep{margin:0 10px;opacity:.5}

  .pillar{padding:90px 0;border-top:1px solid var(--line)}
  .pillar:first-of-type{border-top:0}
  .pillar .wrap{display:grid;grid-template-columns:.9fr 1.6fr;gap:80px;align-items:start}
  @media(max-width:900px){.pillar .wrap{grid-template-columns:1fr;gap:40px}}
  .pillar .num{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
  .pillar h2{font-family:var(--serif);font-weight:300;font-size:clamp(36px,4vw,58px);line-height:1.05;letter-spacing:-.02em;margin-bottom:16px}
  .pillar h2 em{font-style:italic;color:var(--orange);font-weight:400}
  .pillar p.intro{font-size:17px;color:var(--muted);line-height:1.6;max-width:46ch}

/* FINAL — mobile menu base (no media query) */
.mobile-menu{position:fixed !important;inset:0;z-index:200;background:var(--bg);color:var(--ink);padding:90px 28px 40px;transform:translateY(-100%);transition:transform .35s cubic-bezier(.2,.6,.2,1);display:flex;flex-direction:column;gap:4px;overflow-y:auto;visibility:hidden}
.mobile-menu.open{transform:translateY(0) !important;visibility:visible !important}
.mobile-menu a{font-family:var(--serif);font-weight:300;font-size:32px;letter-spacing:-.02em;padding:14px 0;border-bottom:1px solid var(--line);color:var(--ink);display:flex;align-items:center;justify-content:space-between;text-decoration:none}
.mobile-menu a .arr{font-family:var(--mono);font-size:14px;color:var(--muted)}
.mobile-menu a.sub{padding-left:18px;font-size:22px;opacity:.8}
.mobile-menu a.disabled{opacity:.35;pointer-events:none}
.mobile-menu .mm-group-label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:22px 0 6px}
.mobile-menu .mm-ctas{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.mobile-menu .mm-ctas a{font-family:var(--sans);font-size:15px;font-weight:500;letter-spacing:0;padding:16px 22px;border-radius:999px;border:1px solid var(--line);justify-content:center}
.mobile-menu .mm-ctas a.primary{background:var(--orange);color:#fff;border-color:var(--orange)}


@media (max-width:480px){
  .footer{padding:50px 0 24px}
  .footer-big{font-size:clamp(2rem,12vw,3rem) !important;margin:0 0 28px !important}
  .footer-grid{gap:24px !important}
}

  /* Software products: alternating image position */
  .about--reverse .about-inner > .about-img-wrap{order:2}
  .about--reverse .about-inner > .about-body{order:1}
  @media (max-width:900px){.about--reverse .about-inner > .about-img-wrap{order:0}.about--reverse .about-inner > .about-body{order:0}}

/* ── Software responsive overrides ────────────────────────────── */
@media (max-width:1100px){
  main > section.about .about-img-wrap{max-width:100%}
  main > section.about{padding:80px 0}
  main > section.about .about-inner{gap:50px}
}
@media (max-width:760px){
  main > section.about{padding:60px 0}
  main > section.about .about-inner{gap:32px}
  main > section.about .about-body h2{font-size:clamp(1.8rem,7.5vw,2.6rem);line-height:1.05}
  main > section.about .about-body p.lead{font-size:18px}
  main > section.about .about-body p{font-size:16px;line-height:1.55}
  main > section.about .about-body .spot-cta{margin-top:16px !important}
}
@media (max-width:480px){
  main > section.about{padding:48px 0}
  main > section.about .about-inner{gap:24px}
  main > section.about .about-body h2{font-size:clamp(1.6rem,8vw,2.2rem)}
}

/* Scroll-margin per als anchors dels productes — compensa el header fix */
  main > section.about[id]{scroll-margin-top:100px}


/* Kit Digital — segments grid */
  .segments-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:60px}
  @media (max-width:900px){.segments-grid{grid-template-columns:1fr}}
  .segment-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:36px 32px;display:flex;flex-direction:column;gap:14px;transition:transform .2s, box-shadow .2s}
  .segment-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -20px rgba(0,0,0,.15)}
  .segment-num{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
  .segment-card h3{font-family:var(--serif);font-weight:360;font-size:clamp(1.4rem,2.5vw,2rem);line-height:1.1;letter-spacing:-.01em;margin:0}
  .segment-card p{font-size:15px;line-height:1.55;color:var(--ink-2);margin:0}
  .segment-amount{font-family:var(--mono);font-size:14px;color:var(--muted);margin-top:auto;padding-top:16px;border-top:1px solid var(--line-2);text-transform:uppercase;letter-spacing:.14em}
  .segment-amount em{font-family:var(--serif);font-style:italic;color:var(--orange);font-size:clamp(2rem,4vw,2.6rem);font-weight:400;display:block;margin-top:6px;letter-spacing:0;text-transform:none}

/* Assistència — opcions (3 cards) */
  .options-grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;
  }
  @media(max-width:900px){.options-grid{grid-template-columns:1fr}}

  .option-card{
    background:var(--paper);color:var(--ink);text-decoration:none;cursor:pointer;
    border:1px solid var(--line);border-radius:18px;
    padding:36px 32px 30px;
    display:flex;flex-direction:column;gap:14px;min-height:280px;
    transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  }
  .option-card:hover{
    transform:translateY(-3px);
    box-shadow:0 20px 40px -20px rgba(0,0,0,.18);
    border-color:rgba(255,105,0,.35);
  }
  .option-num{
    font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    color:rgba(20,20,20,.45);
  }
  .option-card h3{
    font-family:var(--serif);font-weight:400;
    font-size:1.5rem;line-height:1.15;letter-spacing:-.01em;
  }
  .option-card p{
    color:var(--muted);font-size:15px;line-height:1.55;flex:1;
  }
  .option-cta{
    align-self:flex-start;margin-top:14px;
    font-family:var(--sans);font-size:14px;font-weight:500;
    display:inline-flex;align-items:center;gap:10px;
    padding:12px 20px;border-radius:999px;
    background:var(--orange);color:#fff;
    transition:background .25s, color .25s;
  }
  .option-card:hover .option-cta{background:var(--ink);color:#fff}
  .option-cta svg{transition:transform .25s}
  .option-card:hover .option-cta svg{transform:translateX(3px)}

  /* Card destacada (Card 2 — Descarregar) */
  .option-card--featured{
    background:var(--ink);color:#fff;
    border-color:rgba(255,255,255,.08);
  }
  .option-card--featured h3{color:#fff}
  .option-card--featured p{color:rgba(255,255,255,.72)}
  .option-card--featured .option-num{color:rgba(255,255,255,.5)}
  .option-card--featured .option-cta{background:var(--orange)}
  .option-card--featured .option-cta:hover{background:#fff;color:var(--ink)}
  .option-card--featured:hover{border-color:rgba(255,105,0,.4)}

