/* ============ RESET / BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;
  line-height:1.55;
  color:#1a1a1a;
  background:#f5efe6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
ul{list-style:none}
section{padding:120px 0;position:relative;overflow:hidden}

.container{
  width:100%;
  max-width:1280px;
  margin:0 auto;
  padding:0 32px;
  position:relative;
}

/* ============ UTILITIES ============ */
.eyebrow{
  font-size:11px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#ff6b35;
  margin-bottom:32px;
  display:inline-block;
}
.eyebrow--light{color:#ffa94d}
.eyebrow--white{color:#fff;opacity:.9}

.big-heading,
.hero__title,
.oc-title,
.cn-title,
.cn-card__title{
  font-family:'Inter','Manrope',sans-serif;
}
.big-heading{
  font-size:clamp(48px,7vw,104px);
  line-height:.95;
  font-weight:800;
  letter-spacing:-.03em;
  color:#fff;
}
.big-heading--dark{color:#0d0d0d}

.grad-text{
  background:linear-gradient(90deg,#ff6b35,#ffb347,#69db7c,#74c0fc,#b197fc,#f06595);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.grad-text-bright{
  background:linear-gradient(90deg,#ff6b35,#ff8c42,#ffb347);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.quoted{color:#ff6b35;font-style:italic}
.quoted-w{
  background:linear-gradient(90deg,#ff6b35,#f06595,#b197fc);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-style:italic;
}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 26px;
  border-radius:999px;
  font-weight:700;
  font-size:14px;
  letter-spacing:.01em;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn--dark{background:#0d0d0d;color:#fff}
.btn--dark:hover{box-shadow:0 12px 30px rgba(0,0,0,.25)}
.btn--orange{
  background:linear-gradient(90deg,#ff6b35,#ff8c42);
  color:#fff;
  box-shadow:0 8px 22px rgba(255,107,53,.35);
}
.btn--orange:hover{box-shadow:0 14px 34px rgba(255,107,53,.55)}
.btn--outline{
  background:transparent;
  color:#0d0d0d;
  border:1.5px solid #0d0d0d;
}
.btn--outline:hover{background:#0d0d0d;color:#fff}

.link-arrow{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:600;color:#0d0d0d;font-size:14px;
  text-decoration:underline;text-underline-offset:6px;
}
.link-arrow:hover{color:#ff6b35}

/* ============ NAVIGATION ============ */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(245,239,230,.85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,.04);
}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 32px;
}
.logo,.logo-inline{
  display:inline-flex;
  align-items:center;
  line-height:1;
}
.logo img{height:34px;width:auto;display:block}
.logo-inline{vertical-align:middle}
.logo-inline img{height:.9em;width:auto;display:inline-block;vertical-align:-.08em}
.nav__links{display:flex;gap:32px}
.nav__links a{
  font-size:14px;font-weight:600;color:#0d0d0d;
  position:relative;transition:color .2s;
}
.nav__links a:hover{color:#ff6b35}
.nav__links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;
  background:#ff6b35;transform:scaleX(0);transition:transform .25s;
  transform-origin:left;
}
.nav__links a:hover::after{transform:scaleX(1)}

.nav__toggle{display:none;width:36px;height:36px;flex-direction:column;justify-content:center;gap:5px;align-items:center}
.nav__toggle span{width:22px;height:2px;background:#0d0d0d;border-radius:2px}

/* ============ HERO ============ */
.hero{padding:40px 0 80px;background:#f5efe6}
.hero__inner{
  display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center;
}
.hero__title{
  font-size:clamp(44px,6vw,88px);
  line-height:.98;
  font-weight:800;
  letter-spacing:-.045em;
  position:relative;
  margin-bottom:28px;
}
.tyjo-text{
  background:linear-gradient(90deg,#ff6b35 0%,#ff7a3a 38%,#4dabf7 62%,#7c5cff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;
  font-size:1.15em;
  line-height:1;
  padding-bottom:.16em;
  position:relative;
  top:-.08em;
}
.underline-orange{color:#ff6b35;}

.sparkles{
  position:absolute;
  left:-40px;top:-30px;
  width:50px;height:30px;
  display:block;
  pointer-events:none;
}
.sp{
  position:absolute;
  width:9px;height:9px;border-radius:50%;
  display:block;
}
.sp--pink{background:#ec4899;top:14px;left:0}
.sp--blue{background:#3b82f6;top:2px;left:20px}
.sp--green{background:#22c55e;top:18px;left:38px}

.sparkles-inline{
  display:inline-block;
  position:relative;
  width:1.2em;height:.7em;
  vertical-align:-.35em;
  margin-left:.2em;
  pointer-events:none;
}
.spi{
  position:absolute;
  width:8px;height:8px;
  background:#ff6b35;border-radius:50%;
}
.spi--1{top:.05em;left:10%}
.spi--2{top:.3em;left:55%}
.hero__text{
  font-size:17px;
  line-height:1.65;
  max-width:480px;
  color:#3a3a3a;
  margin-bottom:36px;
}
.hero__cta{display:flex;align-items:center;gap:24px;flex-wrap:wrap}

.hero__right{position:relative;min-height:560px;display:flex;align-items:center;justify-content:center}
.gallery{
  position:relative;width:100%;max-width:640px;aspect-ratio:1.32 / 1;
}
.blob{
  position:absolute;border-radius:50%;z-index:1;
}
.blob--purple{
  width:200px;height:200px;
  background:#7c5cff;
  top:-30px;right:80px;
}
.blob--blue{
  width:140px;height:140px;
  background:#4f7cff;
  bottom:-40px;left:38%;
}
.gallery__photo{
  position:absolute;inset:30px 0 30px 30px;
  border-radius:24px;
  background-image:url('hero%20image.png');
  background-size:cover;background-position:center;
  box-shadow:0 30px 80px rgba(0,0,0,.22);
  z-index:2;
}
.tyjo-badge{
  position:absolute;
  left:-30px;bottom:-30px;
  width:170px;height:170px;
  border-radius:50%;
  z-index:5;
  box-shadow:0 22px 50px rgba(35,196,106,.35);
  animation:bob 5s ease-in-out infinite;
}
.tyjo-img{width:100%;height:100%;display:block}
@keyframes bob{
  0%,100%{transform:translateY(0) rotate(-4deg)}
  50%{transform:translateY(-8px) rotate(4deg)}
}

/* ============ MANIFESTO ============ */
.manifesto{
  background:#050505;
  color:#fff;
  position:relative;
  isolation:isolate;
}
.manifesto__glow{
  position:absolute;border-radius:50%;
  filter:blur(120px);opacity:.55;z-index:0;pointer-events:none;
}
.manifesto__glow--left{
  width:520px;height:520px;background:#ff5722;
  left:-180px;bottom:-160px;
}
.manifesto__glow--right{
  width:480px;height:480px;background:#ff6b35;
  right:-160px;bottom:-200px;opacity:.35;
}
.manifesto>.container{position:relative;z-index:1}

.manifesto__eyebrow{
  display:flex;align-items:center;gap:14px;margin-bottom:80px;
}
.dots{display:inline-flex;gap:6px}
.dots span{width:10px;height:10px;border-radius:50%;display:inline-block}
.eyebrow--white-faint{
  color:rgba(255,255,255,.65);margin-bottom:0;font-weight:700;
}

.manifesto__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  margin-bottom:90px;
  position:relative;
  align-items:center;
}
.manifesto__grid::before{
  content:"";
  position:absolute;
  left:50%;top:8px;bottom:8px;
  width:2px;margin-left:-1px;
  background:linear-gradient(180deg,#ff6b35,#ffd166,#69db7c,#74c0fc,#b197fc,#f06595);
  border-radius:2px;
  pointer-events:none;
}
.manifesto__title{position:relative}
.manifesto__title h2{color:#f5efe6}
.manifesto__title h2 + h2{margin-top:48px}
.big-heading--spaced{line-height:1.05}
.orange-text{
  background:linear-gradient(180deg,#ff6b35,#ff5722);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.underline-rainbow{
  position:relative;display:inline-block;padding-bottom:14px;
}
.underline-rainbow::after{
  content:"";position:absolute;left:0;right:0;bottom:6px;height:3px;
  background:linear-gradient(90deg,#ff6b35,#ffd166,#69db7c,#74c0fc,#b197fc,#f06595);
  border-radius:3px;
}

.manifesto__text{
  font-size:20px;line-height:1.5;color:#d4d4d4;
  max-width:560px;
  position:relative;
  font-weight:500;
  padding-top:8px;
}
.manifesto__text p{margin-bottom:26px}
.manifesto__text p:last-child{margin-bottom:0}
.manifesto__text strong{color:#fff;font-weight:800}
.manifesto__text .accent{
  color:#ff6b35;font-style:italic;font-weight:700;
}

.floating-dot{
  position:absolute;width:10px;height:10px;border-radius:50%;
}
.floating-dot--orange{top:-30px;right:30%;background:#ff6b35}
.floating-dot--green{top:-18px;left:8px;background:#69db7c}

.quote-banner{
  position:relative;
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  background:linear-gradient(90deg,#e34a9f 0%,#ff5e8a 18%,#ff7e3a 55%,#ffd166 100%);
  padding:36px 44px;border-radius:16px;
  color:#0d0d0d;
  box-shadow:0 24px 60px rgba(255,107,53,.25);
}
.quote-banner p{font-size:22px;font-weight:500;line-height:1.4;flex:1;max-width:none}
.quote-banner__italic{font-style:italic;font-weight:500;margin-right:6px}
.quote-banner strong{font-weight:800}
.quote-banner__icon{
  flex-shrink:0;
  color:#0d0d0d;
  display:grid;place-items:center;
  padding-right:8px;
}
.quote-banner__icon svg{width:46px;height:46px}

/* ============ POSITIONING ============ */
.positioning{
  background:#f5efe6;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.bg-word{
  position:absolute;
  top:20px;right:-40px;
  font-family:'Manrope',sans-serif;
  font-weight:800;
  font-size:clamp(180px,22vw,300px);
  letter-spacing:-.04em;
  line-height:.9;
  color:#0d0d0d;
  opacity:.045;
  z-index:0;
  pointer-events:none;
  user-select:none;
}
.ring-pink{
  position:absolute;
  top:-60px;left:-50px;
  width:140px;height:140px;border-radius:50%;
  border:3px solid #f783ac;
  z-index:0;
  pointer-events:none;
}
.pos-dot{
  position:absolute;border-radius:50%;z-index:0;pointer-events:none;
}
.pos-dot--1{width:10px;height:10px;background:#b197fc;top:120px;left:48%}
.pos-dot--2{width:8px;height:8px;background:#ff6b35;top:300px;right:80px}
.pos-dot--3{width:9px;height:9px;background:#69db7c;top:520px;right:120px}
.pos-dot--4{width:8px;height:8px;background:#4dabf7;bottom:80px;left:60px}
.pos-dot--5{width:7px;height:7px;background:#ffd166;top:760px;left:46%}
.pos-dot--6{width:9px;height:9px;background:#f783ac;top:540px;left:54%}

.positioning>.container{position:relative;z-index:1}

.positioning__grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:80px;
  align-items:center;margin-bottom:60px;
}
.positioning__title{position:relative}
.positioning__last{display:inline-block;margin-top:14px}
.quoted{
  color:#ff6b35;
  font-style:italic;
  font-weight:800;
}
.positioning__text{
  font-size:20px;line-height:1.5;color:#3a3a3a;max-width:520px;
  font-weight:500;
}
.positioning__text p{margin-bottom:26px}
.positioning__text p:last-child{margin-bottom:0}
.positioning__text strong{color:#0d0d0d;font-weight:800}

.dashed-rainbow{
  display:flex;gap:8px;margin-bottom:60px;
}
.dashed-rainbow span{
  width:50px;height:4px;border-radius:4px;display:inline-block;
}

.pillars{
  display:grid;grid-template-columns:repeat(4,1fr);gap:22px;
  max-width:1080px;
}
.pillar{
  position:relative;
  background:#faf6ed;
  border-radius:18px;
  padding:28px 26px 32px;
  border:1px solid rgba(0,0,0,.05);
  box-shadow:0 12px 30px rgba(0,0,0,.04);
  transition:transform .25s ease,box-shadow .25s ease;
  overflow:hidden;
}
.pillar:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.08)}
.pillar__bar{
  position:absolute;top:0;left:24px;width:50px;height:4px;
  background:var(--c);border-radius:0 0 4px 4px;
}
.pillar__num{
  display:block;
  font-weight:700;
  font-size:48px;
  letter-spacing:-.02em;
  line-height:1;
  margin:18px 0 28px;
  color:var(--c);
  opacity:.85;
}
.pillar h3{
  font-size:22px;font-weight:800;margin-bottom:20px;
  color:#0d0d0d;letter-spacing:-.01em;
  position:relative;display:inline-block;padding-bottom:12px;
}
.pillar h3::after{
  content:"";position:absolute;
  left:0;bottom:0;
  width:38px;height:3px;
  background:var(--c);border-radius:3px;
}
.pillar p{font-size:14px;color:#5a5a5a;line-height:1.55}

/* ============ SERVICES ============ */
.services{
  background:#050505;
  color:#fff;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.svc-glow{
  position:absolute;border-radius:50%;
  filter:blur(120px);opacity:.22;z-index:0;pointer-events:none;
}
.svc-glow--tl{width:480px;height:480px;background:#f06595;top:-180px;left:-160px}
.svc-glow--tr{width:520px;height:520px;background:#ff9966;top:-200px;right:-180px}
.svc-glow--bl{width:440px;height:440px;background:#69db7c;bottom:-180px;left:-140px}
.svc-glow--br{width:480px;height:480px;background:#b197fc;bottom:-180px;right:-160px}
.services>.container{position:relative;z-index:1}

.services__eyebrow{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:32px}
.eyebrow-line{display:inline-block;width:48px;height:2px;background:#ff8c42;border-radius:2px}
.eyebrow--yellow{color:#ffd28a;margin-bottom:0}

.services__title{
  margin-bottom:28px;
  max-width:1100px;
}
.services__lead{
  font-size:17px;color:#bfbfbf;line-height:1.6;
  max-width:840px;margin-bottom:80px;
}

.service-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.svc-card{
  position:relative;
  background:linear-gradient(180deg,#161616 0%,#0c0c0c 100%);
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  padding:30px 30px 32px;
  overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.svc-card:hover{
  transform:translateY(-6px);
  border-color:color-mix(in srgb,var(--c) 50%,transparent);
  box-shadow:0 24px 60px color-mix(in srgb,var(--c) 18%,transparent);
}
.svc-card__bar{
  position:absolute;top:0;left:30px;width:48px;height:3px;
  background:var(--c);border-radius:0 0 3px 3px;
}
.svc-card__glow{
  position:absolute;top:30px;right:24px;
  width:14px;height:14px;border-radius:50%;
  background:var(--c);opacity:.35;
  filter:blur(8px);
}
.svc-card__glow::after{
  content:"";position:absolute;inset:4px;border-radius:50%;
  background:var(--c);opacity:.6;
}
.svc-card__num{
  display:block;
  font-weight:800;
  font-size:60px;
  line-height:1;
  letter-spacing:-.03em;
  color:var(--c);
  margin:14px 0 22px;
}
.svc-card h3{
  font-size:22px;font-weight:800;line-height:1.2;
  color:#fff;letter-spacing:-.01em;
  margin-bottom:18px;
}
.svc-card__divider{
  display:block;width:40px;height:2px;
  background:var(--c);opacity:.8;border-radius:2px;
  margin-bottom:18px;
}
.svc-card p{font-size:14px;color:#a8a8a8;line-height:1.65}

/* ============ FIT (Kdy se hodíme) ============ */
.fit{
  background:#f5efe6;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.fit-rings{position:absolute;inset:0;z-index:0;pointer-events:none}
.fit-rings span{
  position:absolute;border-radius:50%;border:2px solid;background:transparent;opacity:.55;
}
.fit-dot{position:absolute;border-radius:50%;background:#ff6b35;z-index:0;pointer-events:none}
.fit-dot--1{width:8px;height:8px;bottom:60px;left:60px}
.fit-dot--2{width:9px;height:9px;bottom:120px;right:24%}

.fit>.container{position:relative;z-index:1}

.fit__eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.eyebrow-mini-line{display:inline-block;width:34px;height:2px;background:#bdb6a8;border-radius:2px}
.fit__eyebrow-text{margin-bottom:48px}

.fit__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:90px;align-items:start;margin-bottom:120px}
.fit__left{position:relative}
.fit__title{margin-bottom:24px}
.dashed-rainbow--with-dot{
  position:relative;margin-bottom:32px;align-items:center;
}
.dashed-rainbow span{width:50px;height:4px;border-radius:4px;display:inline-block}
.dashed-rainbow .dr-dot{
  width:10px;height:10px;border-radius:50%;display:inline-block;margin-left:6px;
}
.fit__text{
  font-size:16px;line-height:1.7;color:#3a3a3a;
  max-width:540px;margin-bottom:40px;
}

.fit-list{
  display:flex;flex-direction:column;
}
.fit-row{
  display:flex;align-items:center;gap:20px;
  padding:18px 6px;
  border-top:1px solid rgba(0,0,0,.08);
  position:relative;
  cursor:pointer;
  background:transparent;
  border-radius:0;
  margin:0;
  transition:background-color .25s ease, padding .25s ease, margin .25s ease, border-color .25s ease, box-shadow .25s ease, transform .2s ease;
}
.fit-row:first-child{border-top:0}
.fit-row:not(.fit-row--active):hover{transform:translateX(4px)}

.fit-row__num{
  width:42px;height:42px;border-radius:9px;
  display:grid;place-items:center;flex-shrink:0;
  background:var(--c);color:#fff;font-weight:800;font-size:14px;
  box-shadow:0 6px 16px color-mix(in srgb,var(--c) 30%,transparent);
  transition:transform .25s ease;
}
.fit-row__body{flex:1;min-width:0}
.fit-row__body h4{
  font-size:24px;font-weight:800;color:#0d0d0d;
  letter-spacing:-.01em;line-height:1.15;
  margin:0;
}
.fit-row__body p{
  font-size:13px;color:#666;font-weight:500;
  margin-top:4px;
  max-height:0;opacity:0;overflow:hidden;
  transition:max-height .3s ease, opacity .25s ease, margin-top .25s ease;
}

.fit-row__bullet{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;
  background:var(--c);
  box-shadow:0 4px 12px color-mix(in srgb,var(--c) 40%,transparent);
  opacity:0;transform:scale(.4);
  transition:opacity .25s ease, transform .25s ease;
}
.fit-tab{
  position:absolute;left:-10px;top:50%;width:14px;height:28px;
  background:var(--c);border-radius:4px 0 0 4px;
  transform:translate(-6px,-50%) scaleX(0);
  transform-origin:right center;
  opacity:0;
  transition:transform .25s ease, opacity .25s ease;
}

.fit-row--active{
  background:#fbf4e8;
  border-radius:18px;
  border:1px solid color-mix(in srgb,var(--c) 45%,transparent);
  border-top:1px solid color-mix(in srgb,var(--c) 45%,transparent);
  padding:18px 22px;
  margin:6px 0 12px;
  box-shadow:0 14px 34px color-mix(in srgb,var(--c) 18%,transparent);
}
.fit-row--active + .fit-row{border-top:0}
.fit-row--active .fit-row__body p{
  max-height:60px;opacity:1;margin-top:4px;
}
.fit-row--active .fit-row__bullet{opacity:1;transform:scale(1)}
.fit-row--active .fit-tab{opacity:1;transform:translate(0,-50%) scaleX(1)}

.dashed-rainbow--wide{
  margin-top:40px;justify-content:center;align-items:center;
}
.dashed-rainbow--wide span{width:180px;height:5px}

/* ============ WHY ============ */
.why{
  background:#050505;
  color:#fff;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
.why-glow{
  position:absolute;border-radius:50%;
  filter:blur(140px);opacity:.35;z-index:0;pointer-events:none;
}
.why-glow--tl{width:380px;height:380px;background:#ffd166;top:-160px;left:-160px;opacity:.18}
.why-glow--br{width:560px;height:560px;background:#7c5cff;bottom:-200px;right:-180px}
.why>.container{position:relative;z-index:1}

.why__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center}
.why__left{padding-right:20px}
.eyebrow--orange{color:#ff8c42;margin-bottom:32px}
.why__title{
  margin-bottom:28px;
}
.why__qmark{color:#fff;font-weight:800}

.why__bar{
  height:3px;
  width:380px;max-width:100%;
  background:linear-gradient(90deg,#f06595,#ff8c42,#ffd166,#69db7c,#4dabf7,#b197fc);
  border-radius:3px;
  margin-bottom:36px;
  position:relative;
}
.why__bar::after{
  content:"";position:absolute;
  right:-14px;top:50%;
  width:8px;height:8px;border-radius:50%;
  background:#b197fc;
  transform:translateY(-50%);
}

.why__text{
  font-size:16px;line-height:1.65;color:#bfbfbf;
  max-width:420px;
}
.why__text strong{color:#fff;font-weight:800}

.logo-inline{
  display:inline-flex;align-items:center;line-height:1;vertical-align:middle;
}
.logo-inline img{height:1.05em;width:auto;display:inline-block;vertical-align:-.04em}

.why-cards{display:flex;flex-direction:column;gap:20px}
.why-card{
  position:relative;
  display:grid;
  grid-template-columns:auto 1px 1fr;
  gap:28px;
  align-items:center;
  background:linear-gradient(180deg,rgba(20,20,20,.85),rgba(10,10,10,.85));
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;
  padding:26px 30px;
  transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;
}
.why-card:hover{
  transform:translateX(4px);
  border-color:color-mix(in srgb,var(--c) 35%,transparent);
  box-shadow:0 16px 40px color-mix(in srgb,var(--c) 14%,transparent);
}
.why-card__dot{
  position:absolute;
  top:18px;left:22px;
  width:8px;height:8px;border-radius:50%;
  background:var(--c);
  box-shadow:0 0 12px color-mix(in srgb,var(--c) 60%,transparent);
}
.why-card__icon{
  width:68px;height:68px;
  border-radius:50%;
  border:1.5px solid var(--c);
  background:color-mix(in srgb,var(--c) 10%,transparent);
  color:var(--c);
  display:grid;place-items:center;
  flex-shrink:0;
}
.why-card__icon svg{width:30px;height:30px}
.why-card__divider{
  width:1px;height:64px;
  background:var(--c);
  opacity:.45;
}
.why-card__body h3{
  font-size:22px;font-weight:800;
  letter-spacing:-.01em;line-height:1.2;
  color:#fff;margin-bottom:10px;
}
.why-card__body p{
  font-size:14px;color:#a8a8a8;line-height:1.6;
}

/* ============ TEAM ============ */
.team{background:#f7f1e7;position:relative;overflow:hidden;padding-bottom:60px}
.venues{padding-top:60px}
.team__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.team__left{padding-right:20px}
.team__title{margin-bottom:32px;line-height:1.02}
.team__accent{
  position:relative;display:inline-block;
  color:#f5b800;
  padding-bottom:.05em;
}
.team__accent::after{
  content:"";position:absolute;
  left:-4px;right:-4px;
  bottom:.04em;
  height:.18em;
  background:#fbbf24;
  border-radius:6px;
  z-index:-1;
}
.team__text{font-size:15px;line-height:1.65;color:#3a3a3a;max-width:440px;margin-bottom:36px}

.btn--yellow{
  background:linear-gradient(180deg,#fbbf24,#f59e0b);
  color:#0d0d0d;
  box-shadow:0 8px 22px rgba(251,191,36,.35);
}
.btn--yellow:hover{box-shadow:0 14px 34px rgba(251,191,36,.55)}

.team-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  position:relative;
}

.team-tyjo{
  position:absolute;
  top:-28px;right:-28px;
  width:78px;height:78px;border-radius:50%;
  box-shadow:0 12px 28px rgba(252,196,25,.45);
  z-index:20;
  transform:rotate(-6deg);
}

.team-card{
  position:relative;
  background:linear-gradient(140deg,
    color-mix(in srgb, var(--bg) 60%, #fff) 0%,
    var(--bg) 45%,
    color-mix(in srgb, var(--bg) 55%, #fff) 100%);
  border-radius:22px;
  padding:14px 16px 18px;
  box-shadow:0 18px 36px rgba(0,0,0,.1);
  transition:transform .25s ease,box-shadow .25s ease;
  overflow:hidden;
}
.team-card:nth-child(1){z-index:5;transform:rotate(-3.2deg) translateY(2px)}
.team-card:nth-child(2){z-index:4;transform:rotate(2.4deg) translateY(10px);margin-left:-18px}
.team-card:nth-child(3){z-index:3;transform:rotate(-1.6deg) translateY(-4px);margin-left:-18px}
.team-card:nth-child(4){z-index:5;transform:rotate(1.8deg) translateY(6px)}
.team-card:nth-child(5){z-index:4;transform:rotate(-3deg) translateY(-2px);margin-left:-18px}
.team-card:nth-child(6){z-index:3;transform:rotate(3.6deg) translateY(8px);margin-left:-18px}
.team-card:hover{
  transform:translateY(-8px) rotate(0deg);
  box-shadow:0 28px 56px rgba(0,0,0,.18);
  z-index:10;
}

.team-card__photo{
  width:100%;aspect-ratio:1.25/1;
  border-radius:14px;overflow:hidden;margin-bottom:14px;
}
.team-card__photo img{
  width:100%;height:100%;
  object-fit:cover;object-position:50% 18%;
  display:block;
}

.team-card__dot{
  position:absolute;top:24px;right:22px;
  width:10px;height:10px;border-radius:50%;
  background:var(--c);
  box-shadow:0 0 0 3px rgba(255,255,255,.55);
  z-index:2;
}
.team-card__line{
  display:block;width:32px;height:3px;
  background:var(--c);border-radius:3px;
  margin:0 0 8px;
}
.team-card__role{
  display:block;
  font-size:10px;font-weight:800;letter-spacing:.16em;
  color:var(--c);text-transform:uppercase;
  margin-bottom:6px;
}
.team-card h4{
  font-size:21px;font-weight:800;color:#0d0d0d;
  letter-spacing:-.01em;line-height:1.15;
  margin:0 0 12px;
}
.team-card > p{
  font-size:13px;line-height:1.5;
  font-style:italic;color:#444;
  margin:0;
}

/* +40 Dalších */
.team-card--more{
  background:linear-gradient(180deg,#fbbf24 0%,#f59e0b 70%,#ea8a06 100%);
  padding:24px 22px;
  display:flex;flex-direction:column;
  color:#fff;
}
.team-card__partners{
  font-size:10px;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:#fff;
  display:block;
}
.team-card__big{
  font-size:42px;font-weight:800;line-height:1.05;
  color:#fff;letter-spacing:-.02em;
  margin:auto 0;
}
.team-card--more p{
  font-size:12px;color:rgba(255,255,255,.95);
  font-weight:500;line-height:1.5;
  margin-top:14px;
  font-style:normal;
}

.team__rainbow{
  margin-top:60px;justify-content:center;
}

/* ============ VENUES ============ */
.venues{background:#f5efe6;position:relative;overflow:hidden}
.v-dot{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.venues>.container{position:relative;z-index:1}

.venues__eyebrow{display:flex;flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:28px}

.orange-text-solid{color:#ff5722}

.venues__title{margin-bottom:32px;line-height:1.02}
.venues__text{
  font-size:15px;line-height:1.65;color:#3a3a3a;
  max-width:720px;margin-bottom:64px;
}

.venues-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}

.venue{
  display:grid;
  grid-template-columns:1fr 1fr;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 14px 30px rgba(0,0,0,.06);
  transition:transform .25s ease,box-shadow .25s ease;
}
.venue:hover{transform:translateY(-4px);box-shadow:0 22px 50px rgba(0,0,0,.1)}

.venue__photo{
  position:relative;
  min-height:240px;
  overflow:hidden;
}
.venue__photo img{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.venue__edge{
  position:absolute;
  right:0;top:0;bottom:0;
  width:3px;
  background:var(--c);
  z-index:3;
}

.venue__chip{
  position:absolute;
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;
  border-radius:999px;
  font-weight:700;
  z-index:2;
  white-space:nowrap;
}
.venue__chip--tag{
  top:14px;left:14px;
  background:rgba(15,15,15,.78);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:#fff;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.v-chip-dot{
  width:7px;height:7px;border-radius:50%;
  display:inline-block;
}
.venue__chip--cap{
  bottom:14px;left:14px;
  background:rgba(255,255,255,.96);
  color:var(--c);
  font-size:12px;
  font-weight:700;
}
.venue__chip--cap svg{color:var(--c);flex-shrink:0}

.venue__body{
  padding:28px 28px;
  display:flex;flex-direction:column;justify-content:center;
}
.venue__body h4{
  font-size:26px;font-weight:800;color:#0d0d0d;
  letter-spacing:-.015em;line-height:1.08;
  margin-bottom:10px;
}
.venue__loc{
  font-size:11px;font-weight:800;letter-spacing:.16em;
  color:var(--c);text-transform:uppercase;
  margin-bottom:14px;
}
.venue__desc{
  font-size:13px;color:#555;line-height:1.55;
}

.venues__cta{display:flex;justify-content:center;margin-top:56px}
.btn-rainbow{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 28px;
  border-radius:999px;
  background:#fff;color:#0d0d0d;
  font-weight:700;font-size:14px;
  position:relative;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  transition:transform .2s ease,box-shadow .2s ease;
}
.btn-rainbow::before{
  content:"";
  position:absolute;inset:0;
  border-radius:999px;
  padding:2px;
  background:linear-gradient(90deg,#f06595,#ff8c42,#ffd166,#69db7c,#4dabf7,#b197fc);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
          mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
}
.btn-rainbow:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(0,0,0,.12)}
.btn-rainbow svg{flex-shrink:0}

/* ============ ORANGE CTA ============ */
.orange-cta{
  background:linear-gradient(180deg,#ff8243 0%,#ff5722 55%,#ed4500 100%);
  color:#0d0d0d;
  text-align:center;
  padding:100px 0 120px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.oc-ring{
  position:absolute;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.22);
  pointer-events:none;z-index:0;
}
.oc-ring--tr{width:480px;height:480px;top:-180px;right:-160px}
.oc-ring--bl{width:440px;height:440px;bottom:-140px;left:-180px}
.oc-spot{position:absolute;border-radius:50%;z-index:0;pointer-events:none}

.tyjo-circle{
  position:absolute;z-index:3;
  width:160px;height:160px;border-radius:50%;
  box-shadow:0 24px 60px rgba(0,0,0,.18);
  pointer-events:none;
}
.tyjo-circle--tl{top:60px;left:60px;transform:rotate(-6deg)}
.tyjo-circle--br{bottom:60px;right:60px;width:130px;height:130px;transform:rotate(6deg)}

.oc-dots-grid{
  position:absolute;
  left:140px;bottom:260px;
  width:170px;height:90px;
  z-index:0;pointer-events:none;
}
.oc-dots-grid span{
  position:absolute;
  width:5px;height:5px;border-radius:50%;
}

.orange-cta>.container{position:relative;z-index:2}

.oc-eyebrow{
  display:flex;flex-direction:column;align-items:center;
  margin-bottom:40px;
}
.oc-eyebrow-text{
  color:rgba(255,255,255,.95);margin-bottom:6px;
}
.oc-eyebrow-line{
  width:64px;height:2px;
  background:linear-gradient(90deg,#f06595,#ff8c42,#ffd166,#69db7c,#4dabf7,#b197fc);
  border-radius:2px;
}

.oc-title{
  font-size:clamp(48px,7.5vw,108px);
  font-weight:800;letter-spacing:-.03em;line-height:1.05;
  color:#0d0d0d;
  margin-bottom:80px;
  text-align:center;
}
.oc-title__white{color:#fff}
.oc-title__italic{
  display:inline-block;
  font-style:italic;font-weight:500;
  position:relative;padding:0 .08em 14px;
}
.oc-title__italic em{font-style:italic}
.oc-title__italic::after{
  content:"";position:absolute;
  left:0;right:0;bottom:2px;height:5px;
  background:linear-gradient(90deg,#f06595,#ff8c42,#ffd166,rgba(255,209,102,0));
  border-radius:5px;
}
.oc-title__period{font-style:normal;font-weight:800;color:#0d0d0d}

.oc-cols{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  max-width:900px;margin:0 auto 100px;
  text-align:left;
}
.oc-col{display:flex;gap:18px;align-items:flex-start}
.oc-icon{
  width:36px;height:36px;border-radius:50%;
  border:1.5px solid currentColor;
  display:grid;place-items:center;
  flex-shrink:0;margin-top:2px;
}
.oc-col p{
  font-size:14px;color:#fff;line-height:1.55;font-weight:500;
}

.oc-bottom{text-align:center}
.oc-tyjo{
  font-size:clamp(56px,8vw,96px);
  font-weight:800;line-height:1;
  letter-spacing:-.03em;color:#0d0d0d;
  margin-bottom:18px;
}
.oc-tyjo em{font-style:italic;font-weight:800}
.oc-line{
  display:inline-block;
  width:100px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,#ff6b35,#4dabf7);
  margin-bottom:20px;
}
.oc-tag{
  font-size:clamp(26px,3vw,38px);
  font-style:italic;font-weight:600;
  color:#fff;letter-spacing:-.01em;
}
.oc-tag em{font-style:italic;font-weight:600}
.oc-tag__dot{color:#4dabf7;font-weight:800;font-style:normal}

/* ============ CONTACT ============ */
.contact{
  background:radial-gradient(ellipse at center,#141414 0%,#040404 75%);
  color:#fff;
  padding:120px 0;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.cn-ring{
  position:absolute;border-radius:50%;
  border:1.5px solid;
  pointer-events:none;z-index:0;
}
.cn-ring--tl{
  width:420px;height:420px;
  top:-120px;left:-200px;
  border-color:rgba(255,140,66,.55);
}
.cn-ring--tr{
  width:360px;height:360px;
  top:-80px;right:-140px;
  border-color:rgba(177,151,252,.6);
}
.cn-dash{
  position:absolute;
  width:12px;height:2.5px;border-radius:2px;
  pointer-events:none;z-index:0;
  opacity:.85;
}
.contact>.container{position:relative;z-index:1}

.cn-eyebrow-text{
  display:block;text-align:center;margin:0 auto 32px;
}

.cn-title{
  font-size:clamp(40px,5.5vw,80px);
  font-weight:800;letter-spacing:-.02em;line-height:1.1;
  text-align:center;color:#fff;
  margin-bottom:28px;
  max-width:1000px;margin-left:auto;margin-right:auto;
}
.cn-title__quoted{
  background:linear-gradient(90deg,#ff5e8a,#ef4444);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
  font-style:italic;font-weight:800;
  display:inline-block;
  line-height:1.15;
  padding-bottom:.12em;
}

.cn-divider{
  width:280px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,#f06595,#ff8c42,#ffd166,#69db7c,#4dabf7,#b197fc);
  margin:0 auto 32px;
}

.cn-lead{
  text-align:center;
  max-width:840px;margin:0 auto 64px;
  font-size:14px;color:#b8b8b8;line-height:1.65;
}

.cn-card{
  background:#f7f1e7;
  border-radius:22px;
  padding:56px 48px 40px;
  max-width:1180px;margin:0 auto;
  color:#0d0d0d;
  position:relative;
  display:grid;
  grid-template-columns:.78fr 1fr;
  gap:60px;
  box-shadow:0 40px 100px rgba(0,0,0,.55);
}
.cn-card__dots{
  position:absolute;top:18px;left:24px;
  display:flex;gap:8px;
}
.cn-card__dots span{
  width:11px;height:11px;border-radius:50%;
}

.cn-card__left{padding-top:14px;display:flex;flex-direction:column}
.cn-card__title{
  font-size:42px;font-weight:800;
  letter-spacing:-.02em;line-height:1.05;
  margin-bottom:20px;
}
.cn-card__accent{
  background:linear-gradient(90deg,#ff5e8a,#ef4444);
  -webkit-background-clip:text;background-clip:text;
  color:transparent;
}
.cn-card__sub{
  font-size:13px;color:#5a5a5a;line-height:1.6;
  margin-bottom:28px;max-width:340px;
}
.cn-card__line{
  display:block;width:280px;height:2px;
  background:linear-gradient(90deg,#ff8c42,#f06595);
  border-radius:2px;margin-bottom:32px;
}
.cn-info{display:flex;flex-direction:column;gap:16px;margin-top:0}
.cn-info li{display:flex;align-items:center;gap:14px}
.cn-info__icon{
  width:38px;height:38px;border-radius:50%;
  background:#0d0d0d;color:#fff;
  display:grid;place-items:center;
  flex-shrink:0;
}
.cn-info a,.cn-info__caps{
  font-size:14px;color:#0d0d0d;font-weight:700;
}
.cn-info a:hover{color:#ff6b35}
.cn-info__caps{
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
}

.cn-form{
  padding-top:14px;
  display:flex;flex-direction:column;gap:14px;
}
.cn-row{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.cn-field{display:flex;flex-direction:column;gap:8px;flex:1}
.cn-field__label{
  display:flex;align-items:center;gap:8px;
  font-size:10px;font-weight:800;
  letter-spacing:.16em;text-transform:uppercase;
  color:#1a1a1a;
}
.cn-field__dot{
  width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0;
}
.cn-field input,.cn-field textarea{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:10px;
  padding:13px 16px;
  font-size:14px;
  outline:none;
  font-weight:500;
  color:#0d0d0d;
  font-family:inherit;
  transition:border-color .2s,box-shadow .2s;
}
.cn-field input::placeholder,.cn-field textarea::placeholder{color:#999;font-weight:500}
.cn-field input:focus,.cn-field textarea:focus{
  border-color:#ff6b35;
  box-shadow:0 0 0 3px rgba(255,107,53,.12);
}
.cn-field textarea{resize:vertical;min-height:90px}

.cn-foot{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  margin-top:6px;
}
.cn-disclaimer{
  font-size:11px;color:#666;max-width:280px;line-height:1.5;
  margin:0;
}
.cn-submit{padding:14px 24px;transition:opacity .2s ease, transform .2s ease}
.cn-submit.is-loading{opacity:.8;cursor:wait}
.cn-submit.is-loading .cn-submit__arrow{
  display:inline-block;
  animation:cn-spin 1s linear infinite;
}
@keyframes cn-spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

.cn-form__error{
  margin-top:14px;
  font-size:13px;color:#c0392b;
  background:#fde6e1;
  padding:12px 14px;border-radius:10px;
  border:1px solid rgba(192,57,43,.2);
}
.cn-form__error a{color:#c0392b;text-decoration:underline;font-weight:700}

.cn-success[hidden]{display:none}
.cn-success{
  grid-column:1 / -1;
  text-align:center;
  padding:40px 20px 24px;
  display:flex;flex-direction:column;align-items:center;
  animation:cn-pop .45s cubic-bezier(.2,.9,.3,1.1);
}
@keyframes cn-pop{
  0%{opacity:0;transform:translateY(12px) scale(.96)}
  100%{opacity:1;transform:none}
}
.cn-success__icon{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(180deg,#23c46a,#15a356);
  color:#fff;
  display:grid;place-items:center;
  margin-bottom:24px;
  box-shadow:0 14px 30px rgba(35,196,106,.4);
}
.cn-success h3{
  font-size:32px;font-weight:800;
  letter-spacing:-.02em;line-height:1.1;
  color:#0d0d0d;margin-bottom:14px;
}
.cn-success p{
  max-width:480px;
  font-size:14px;color:#555;line-height:1.6;
  margin-bottom:24px;
}
.cn-success__back{
  padding:12px 22px;font-size:13px;
}

/* ============ FOOTER ============ */
.footer{
  background:#0a0a0a;color:#fff;padding:60px 0 30px;
  border-top:1px solid rgba(255,255,255,.05);
}
.footer__inner{
  display:grid;grid-template-columns:1fr 2fr;gap:60px;margin-bottom:40px;
}
.footer__cols{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px;
}
.footer__cols h5{
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:#888;margin-bottom:14px;
}
.footer__cols a{
  display:block;font-size:14px;color:#d0d0d0;margin-bottom:8px;
  transition:color .2s;
}
.footer__cols a:hover{color:#ff6b35}
.footer__bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.06);
  font-size:12px;color:#666;
}

/* ============ RESPONSIVE ============ */
/* Tablet */
@media (max-width:1024px){
  section{padding:80px 0}
  .container{padding:0 28px}

  /* Hero */
  .hero{padding:40px 0 100px}
  .hero__inner{grid-template-columns:1fr;gap:60px}
  .hero__right{min-height:auto;max-width:620px;margin:0 auto;width:100%}
  .gallery{margin:0 auto}

  /* Manifesto */
  .manifesto__grid{grid-template-columns:1fr;gap:36px}
  .manifesto__grid::before{display:none}
  .manifesto__eyebrow{margin-bottom:48px}
  .floating-dot--orange{right:auto;left:40%}

  /* Positioning */
  .positioning__grid{grid-template-columns:1fr;gap:36px;margin-bottom:48px}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .bg-word{font-size:clamp(140px,18vw,220px);top:20px;right:-20px}

  /* Services */
  .services__title{font-size:clamp(40px,7vw,72px)}
  .service-grid{grid-template-columns:repeat(2,1fr)}

  /* Fit */
  .fit__grid{grid-template-columns:1fr;gap:48px;margin-bottom:80px}

  /* Why */
  .why__grid{grid-template-columns:1fr;gap:48px}
  .why__left{padding-right:0}

  /* Team */
  .team__grid{grid-template-columns:1fr;gap:64px}
  .team-cards{grid-template-columns:repeat(3,1fr);gap:18px}
  .team-tyjo{top:-26px;right:-10px;width:68px;height:68px}
  .team-tyjo__text{font-size:16px;top:-3px}
  .team-tyjo__smile{width:24px;height:12px;border-width:2.5px}

  /* Venues */
  .venues-grid{grid-template-columns:1fr;gap:20px}
  .venues__title{font-size:clamp(40px,7vw,72px)}

  /* Orange CTA */
  .orange-cta{padding:100px 0}
  .oc-cols{grid-template-columns:1fr;gap:32px;max-width:560px}
  .tyjo-circle--tl{width:110px;height:110px;top:30px;left:30px}
  .tyjo-circle--br{width:96px;height:96px;bottom:30px;right:30px}
  .tyjo-circle__text{font-size:24px;top:-4px}
  .tyjo-circle--br .tyjo-circle__text{font-size:20px}
  .tyjo-circle__smile{width:32px;height:16px;border-width:3px}
  .tyjo-circle--br .tyjo-circle__smile{width:26px;height:13px;border-width:3px}
  .oc-dots-grid{left:40px;bottom:160px}

  /* Contact */
  .cn-card{grid-template-columns:1fr;gap:40px;padding:48px 36px 32px}
  .cn-card__line{width:100%;max-width:340px}

  /* Footer */
  .footer__inner{grid-template-columns:1fr;gap:32px}
}

/* Mobile */
@media (max-width:720px){
  section{padding:64px 0}
  .container{padding:0 20px}
  .big-heading{font-size:42px;line-height:1.02}

  /* Nav */
  .nav__inner{padding:14px 20px}
  .nav__links{display:none}
  .btn--dark{display:none}
  .nav__toggle{display:flex}
  .logo img{height:28px}

  /* Hero */
  .hero{padding:30px 0 80px}
  .hero__left{text-align:center}
  .hero__left .eyebrow{display:inline-block}
  .hero__title{font-size:52px;line-height:1;letter-spacing:-.04em}
  .hero__title .tyjo-text{top:0;font-size:1em;padding-bottom:.08em}
  .hero__text{font-size:15px;margin-left:auto;margin-right:auto}
  .br-hide-mobile{display:none}
  .hero__cta{flex-direction:column;align-items:stretch;gap:12px}
  .hero__cta .btn{width:100%;justify-content:center}
  .sparkles{display:none}
  .sparkles-inline{display:none}
  .hero__right{min-height:auto}
  .gallery{max-width:100%;aspect-ratio:4/3}
  .blob--purple{width:120px;height:120px;top:-20px;right:20px}
  .blob--blue{width:90px;height:90px;bottom:-20px;left:30%}
  .tyjo-badge{width:96px;height:96px;left:-6px;bottom:-14px}
  .tyjo-badge__text{font-size:22px}
  .tyjo-badge__smile{width:38px;height:18px;border-width:3.5px}
  .gallery__photo{inset:18px 0 18px 18px;border-radius:16px}

  /* Manifesto */
  .manifesto__eyebrow{justify-content:center;margin-bottom:40px}
  .manifesto__title{text-align:center}
  .manifesto__title h2:first-of-type{font-size:26px;line-height:1.15;margin-bottom:24px}
  .manifesto__title h2.big-heading--spaced{font-size:54px;line-height:1}
  .manifesto__title h2.big-heading--spaced br:last-of-type{display:none}
  .manifesto__text{text-align:center;margin-left:auto;margin-right:auto}
  .floating-dot{display:none}
  .quote-banner{flex-direction:row;align-items:center;padding:16px 18px;gap:12px}
  .quote-banner p{font-size:13px;line-height:1.4;flex:1}
  .quote-banner__icon{align-self:center;margin-top:0;flex-shrink:0;width:38px;height:38px}

  /* Positioning */
  .positioning__title br{display:none}
  .pillars{grid-template-columns:1fr;gap:16px}
  .pillar__num{font-size:42px}
  .bg-word{display:none}
  .ring-pink{display:none}
  .dashed-rainbow span{width:32px;height:3px}
  .dashed-rainbow--wide span{width:60px;height:4px}

  /* Services */
  .services__lead{margin-bottom:56px}
  .service-grid{grid-template-columns:1fr;gap:14px}
  .svc-card{padding:24px 22px}
  .svc-card__num{font-size:48px;margin:10px 0 18px}
  .svc-card h3{font-size:19px}

  /* Fit */
  .fit__title br{display:none}
  .fit-row{gap:14px;padding:14px 4px}
  .fit-row__body h4,.fit-row h4{font-size:18px}
  .fit-row__num{width:36px;height:36px;font-size:12px}
  .fit-row--active{padding:14px 14px;border-radius:14px}
  .fit-tab{display:none}

  /* Why */
  .why__bar{width:100%;max-width:280px}
  .why-card{grid-template-columns:auto 1fr;gap:16px;padding:20px}
  .why-card__divider{display:none}
  .why-card__icon{width:54px;height:54px}
  .why-card__icon svg{width:24px;height:24px}
  .why-card__body h3{font-size:18px;margin-bottom:6px}
  .why-card__dot{top:14px;left:18px}

  /* Team */
  .team{padding-bottom:32px}
  .venues{padding-top:32px}
  .team__title br{display:none}
  .team-cards{grid-template-columns:repeat(2,1fr);gap:14px}
  .team-card{padding:12px 12px 16px}
  .team-card h4{font-size:16px}
  .team-card > p{font-size:12px}
  .team-card__role{font-size:9px;letter-spacing:.14em}
  .team-card__big{font-size:34px}
  .team-card__partners{font-size:9px}
  .team-tyjo{width:56px;height:56px;top:-18px;right:-6px}
  .team-tyjo__text{font-size:13px;top:-2px}
  .team-tyjo__smile{width:20px;height:10px;border-width:2.5px}

  /* Venues */
  .venue{grid-template-columns:1fr}
  .venue__photo{min-height:auto;aspect-ratio:1.7/1}
  .venue__edge{display:none}
  .venue__body{padding:20px 22px 24px}
  .venue__body h4{font-size:22px}

  /* Orange CTA */
  .orange-cta{padding:80px 0 90px}
  .oc-title{font-size:54px;line-height:1;margin-bottom:36px;letter-spacing:-.04em}
  .oc-col p{font-size:13px}
  .oc-tyjo{font-size:48px;margin-bottom:12px}
  .oc-tag{font-size:22px}
  .tyjo-circle--tl{width:70px;height:70px;top:20px;left:18px}
  .tyjo-circle--br{width:64px;height:64px;bottom:20px;right:18px}
  .tyjo-circle__text{font-size:16px;top:-3px}
  .tyjo-circle--br .tyjo-circle__text{font-size:14px}
  .tyjo-circle__smile{width:22px;height:11px;border-width:2.5px}
  .tyjo-circle--br .tyjo-circle__smile{width:20px;height:10px;border-width:2.5px}
  .oc-dots-grid{display:none}
  .oc-ring--tr,.oc-ring--bl{width:280px;height:280px}
  .oc-cols{margin-bottom:36px}

  /* Contact */
  .contact{padding:80px 0}
  .cn-title{font-size:32px;line-height:1.15}
  .cn-row{grid-template-columns:1fr;gap:12px}
  .cn-card{padding:46px 20px 24px;border-radius:18px}
  .cn-card__dots{top:16px;left:18px}
  .cn-card__dots span{width:9px;height:9px}
  .cn-card__title{font-size:30px}
  .cn-card__sub{font-size:13px}
  .cn-foot{flex-direction:column;align-items:stretch;gap:14px}
  .cn-disclaimer{max-width:none}
  .cn-submit{width:100%;justify-content:center}
  .cn-ring{display:none}
  .cn-dash{display:none}

  /* Footer */
  .footer__cols{grid-template-columns:1fr 1fr;gap:24px}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
}

/* Very narrow */
@media (max-width:420px){
  .big-heading{font-size:36px}
  .hero__title{font-size:44px}
  .oc-title{font-size:44px}
  .cn-title{font-size:26px}
  .cn-card__title{font-size:26px}
  .manifesto__title h2:first-of-type{font-size:22px}
  .manifesto__title h2.big-heading--spaced{font-size:44px}
  .team-cards{grid-template-columns:1fr}
  .team-card__photo{aspect-ratio:1.6/1}
}

/* ============ Animations on scroll ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ============ Scroll-to-top button ============ */
.scroll-top{
  position:fixed;
  right:32px;bottom:32px;
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(180deg,#ff7a3a,#ff5722);
  color:#fff;
  display:grid;place-items:center;
  border:0;cursor:pointer;
  box-shadow:0 14px 30px rgba(255,87,34,.35);
  z-index:90;
  opacity:0;
  transform:translateY(20px) scale(.9);
  pointer-events:none;
  transition:opacity .3s ease,transform .3s ease,box-shadow .25s ease,background .25s ease;
}
.scroll-top.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.scroll-top:hover{
  transform:translateY(-4px) scale(1.05);
  box-shadow:0 22px 40px rgba(255,87,34,.5);
}
.scroll-top:active{transform:translateY(-1px) scale(1)}
@media (max-width:720px){
  .scroll-top{right:18px;bottom:18px;width:46px;height:46px}
  .scroll-top svg{width:18px;height:18px}
}
